网络安全全套学习路线+网安新手包——新手小白也能学会

网络安全是一门综合性技术领域,核心是通过各类防护手段与安全策略,守护计算机设备、网络架构以及核心数据资源,抵御非法入侵、恶意攻击、信息窃取与系统破坏等各类网络威胁。

行业内常说的红队、渗透测试,主要专注于攻击侧安全技术,模拟黑客行为挖掘漏洞;而蓝队、安全运营、安全运维,则深耕防御侧安全体系,搭建防护壁垒、筑牢安全防线。

一名优秀的网络安全工程师,必须做到攻守兼备。唯有通晓攻击原理、精通防御策略,做到知己知彼,才能从容应对各类网络风险,筑牢网络安全屏障。

二、网络安全怎么入门

网络安全从来不是一门独立的技术,而是根植于计算机底层基础之上的实用应用技术。倘若脱离底层原理盲目学习,很容易流于表面、纸上谈兵,只懂操作表象,却不懂底层逻辑,这样很难在网络安全行业走得长远。

有一定从业基础的朋友可以精准选择入门方向:拥有网络工程经验,适合从网络安全入手;具备软件开发功底,更建议直接深耕 Web 安全与渗透测试领域。

随着学习不断深入、实战经验逐步积累,安全各大细分领域的技术互通性越来越强,这也要求从业者必须拓宽知识面,对各个技术方向都有所涉猎,全面夯实自身综合能力。

网安技能表

三、网络安全的知识多而杂,怎么合理安排学习?

1、基础阶段

中华人民共和国网络安全法 (包含19个知识点)
Linux操作系统 (包含15个知识点)
计算机网络 (包含15个知识点)
SHELL (包含13个知识点)
HTML/CSS (包含45个知识点)
JavaScript (包含42个知识点)
PHP入门(包含13个知识点)
MySQL数据库 (包含32个知识点)
Python (包含19个知识点)

  • 入门的首要步骤是有系统地学习计算机基础知识,即深入研究以下几个基础知识领域:操作系统、协议/网络、数据库、开发语言以及常见漏洞原理。
  • 一旦掌握了前述基础知识,就应着手进行实际操作。
2、渗透阶段

SQL注入的渗透与防御(包含38个知识点)
XSS相关渗透与防御(包含15个知识点)
上传验证渗透与防御(包含14个知识点)
文件包含渗透与防御(包含13个知识点)
CSRF渗透与防御(包含8个知识点)
SSRF渗透与防御(包含6个知识点)
XXE渗透与防御(包含7个知识点)
远程代码执行渗透与防御(包含8个知识点)

  • 熟悉常见漏洞的原理、使用方法和防御等方面的知识是必要的。在进行Web渗透的阶段,了解一些关键工具也是重要的。
  • 需要掌握的主要工具和平台包括:Burp、AWVS、Appscan、Nessus、Sqlmap、Nmap、Shodan、Fofa、以及代理工具SSRS、Hydra、Medusa、Airspoof等。对这些工具的实践可以通过上述提到的开源靶场进行,足以满足需求。
3、安全管理(提升)

渗透报告编写(包含22个知识点)
等级保护2.0(包含51个知识点)
应急响应(包含6个知识点)
代码审计(包含9个知识点)
风险评估(包含12个知识点)
安全巡检(包含14个知识点)
数据安全(包含26个知识点)

  • 主要内容包括渗透测试报告的编写、网络安全等级的定级、应急响应、代码审计、风险评估、安全巡检、数据安全、法律法规汇编等方面。这个阶段主要面向那些已经从事网络安全相关工作,希望提升至管理层职位的人员。如果你的职业方向是网络安全工程师,那么这个阶段的学习可能是可选的。
4、提升阶段(提升)

密码学(包含35个知识点)
JavaSE入门(包含95个知识点)
C语言(包含145个知识点)
C++语言(包含186个知识点)
Windows逆向(包含48个知识点)
CTF夺旗赛(包含38个知识点)
Android逆向(包含42个知识点)

  • 涵盖的内容主要有密码学、JavaSE、C语言、C++、Windows逆向、CTF夺旗赛、Android逆向等。这个阶段的学习主要面向那些已经从事网络安全相关工作,希望提升至进阶安全架构领域的人员。
四、网络安全学习路线

若你真心希望通过自学方式初探Web安全领域,我建议你查阅以下学习路线图。该路线图详细指导每个知识点的学习时长和学习方法,全程自学时间约为半年左右,亲测有效(文末有惊喜)。

1. 网络安全概念学习(2周)
  • 掌握基本概念,包括SQL注入、文件上传、XSS、CSRF、一句话木马等。
  • 使用关键字(SQL注入、文件上传、XSS、CSRF、一句话木马等)进行Google/SecWiki搜索。
  • 阅读《精通脚本黑客》。尽管内容古老并可能存在错误,但仍适合入门。
  • 查阅渗透笔记/视频,了解整个渗透实战过程。使用搜索词(渗透笔记、渗透过程、入侵过程等)。
2. 渗透工具熟悉(3周)
  • 熟悉AWVS、sqlmap、Burp、Nessus、Chopper、Nmap、Appscan等相关工具的使用。
  • 了解这些工具的用途和使用场景,首先通过软件名字在Google/SecWiki上搜索。
  • 下载这些工具的无后门版本进行安装。
  • 学习并实践使用,搜索SecWiki上的具体教材,如Burp的教程、sqlmap。
  • 熟练掌握这些常用工具后,可以考虑安装音速启动,构建渗透工具箱。
3. 渗透实战操作(5周)
  • 掌握渗透的整个阶段,能够独立渗透小型站点。
  • 在网上找渗透视频,思考其中的思路和原理,使用关键字(渗透、SQL注入视频、文件上传入侵、数据库备份、dedecms漏洞利用等等)。
  • 自己找站点或搭建测试环境进行测试,注意隐藏个人身份。
  • 思考渗透主要分为几个阶段,每个阶段需要做哪些工作,例如PTES渗透测试执行标准。
  • 研究SQL注入的种类、注入原理、手动注入技巧。
  • 研究文件上传的原理,包括如何进行截断、双重后缀欺骗(IIS、PHP)、解析漏洞利用(IIS、Nginx、Apache)等,参考上传攻击框架。
  • 研究XSS形成的原理和种类,具体学习方法可以在Google/SecWiki搜索,也可以参考XSS。
  • 研究Windows/Linux提权的方法和具体使用,参考提权。
  • 可以参考开源渗透测试脆弱系统。
4. 关注安全领域动态(1周)
  • 关注安全领域的最新漏洞、安全事件和技术文章。
  • 通过SecWiki浏览每日的安全技术文章和事件。
  • 在Weibo/Twitter关注安全领域的从业人员,尤其是大牛或者同行,每天抽时间浏览。
  • 使用feedly/鲜果订阅国内外安全技术博客,不仅限于国内,多积累关键信息。SecWiki的聚合栏目也是一个不错的选择。
  • 养成习惯,每天主动提交安全技术文章链接到SecWiki,进行分享和积累。
  • 多关注最新漏洞信息,推荐一些平台:exploit-db、CVE中文库、乌云等,实践公开漏洞利用。
5. 熟悉Windows/Kali Linux(3周)
  • 学习Windows/Kali Linux的基本命令和常用工具。
  • 熟悉Windows下的常用cmd命令,例如ipconfig、nslookup、tracert、net、tasklist、taskkill等。
  • 熟悉Linux下的基本命令,如ifconfig、ls、cp、mv、vi、wget、service、sudo等。
  • 掌握Kali Linux系统下的常用工具,可以参考SecWiki、《Web Penetration Testing with Kali Linux》、《Hacking with Kali》等。
  • 熟悉metasploit工具的使用,可以参考SecWiki、《Metasploit渗透测试指南》。
6. 服务器安全配置(3周)
  • 学习服务器环境配置,能够通过思考发现配置中存在的安全问题。
  • 针对Windows 2003/2008环境下的IIS配置,特别注意配置安全和运行权限,参考SecWiki-配置。
  • 针对Linux环境下的LAMP安全配置,主要考虑运行权限、跨目录、文件夹权限等,参考SecWiki-配置。
  • 进行远程系统加固,限制用户名和口令登录,通过iptables限制端口。
  • 配置软件WAF以加强系统安全,在服务器配置mod_security等系统,参见SecWiki-ModSecurity。
  • 使用Nessus软件对配置环境进行安全检测,发现未知安全威胁。
7. 脚本编程学习(4周)
  • 选择脚本语言Perl/Python/PHP/Go/Java中的一种,对常用库进行编程学习。
  • 搭建开发环境并选择合适的IDE,例如PHP环境推荐Wamp和XAMPP,强烈推荐Sublime作为IDE。学习一些Sublime的技巧,参考SecWiki-Sublime。
  • 学习Python编程,包括语法、正则、文件、网络、多线程等常用库,推荐《Python核心编程》,不要一口气看完。
  • 使用Python编写漏洞的exploit,然后编写一个简单的网络爬虫,可参考SecWiki-爬虫、相关视频。
  • 学习PHP的基本语法并编写一个简单的博客系统,可参考《PHP与MySQL程序设计(第4版)》和相关视频。
  • 熟悉MVC架构,尝试学习一个PHP框架或Python框架(可选)。
  • 了解Bootstrap的布局或CSS,可参考SecWiki-Bootstrap。
8. 源码审计与漏洞分析(3周)
  • 能够独立分析脚本源码程序并发现安全问题。
  • 熟悉源码审计的动态和静态方法,并知道如何分析程序,参见SecWiki-审计。
  • 从乌云等平台寻找开源程序的漏洞进行分析并尝试自己分析。
  • 了解Web漏洞的形成原因,通过关键字查找分析,参见SecWiki-代码审计、高级PHP应用程序漏洞审核技术。
  • 研究Web漏洞的形成原理以及如何从源码层面避免该类漏洞,并整理成检查清单。
9. 安全体系设计与开发(5周)
  • 能够建立自己的安全体系,并能提出一些安全建议或系统架构。
  • 开发一些实用的安全小工具并开源,展现个人实力。
  • 建立自己的安全体系。

五、网络安全前景

网络安全领域发展迅速,未来的发展趋势也十分值得关注。可以选择从事以下方面的职业:网络安全工程师、渗透测试员、安全分析师、网络安全经理、安全顾问等。

一线城市3-5年的薪资都在3W+

三、网络安全学习路线

先放上路线图
在这里插入图片描述

需要的话可以扫描下方卡片加我耗油发给你(都是无偿分享的),大家也可以一起学习交流一下。

网络安全学习路线&学习资源在这里插入图片描述

第一阶段:基础操作入门

入门的第一步是学习一些当下主流的安全工具课程并配套基础原理的书籍,一般来说这个过程在1个月左右比较合适。在这个部分我介绍的课程和书籍都属于难度非常低的,就算是完全零基础的小白只要认真学也是能够学会的

课程我推荐下面这套Web安全入门基础课程,难度不大而且完全免费。这套课程至今已经有19万的学习人次,好评度99%。一共包含了40节课,课程内容主要包含了burp、awvs、cs、msf等当下主流工具的使用,而且每节课程都配备了练习靶场。听完课程后再去靶场进行练习,靶场当中有任何不懂的问题也可以在学习群里请教前辈,这样能够大大提升你的学习效率

在学习基础入门课程的同时,推荐同时阅读相关的书籍补充理论知识,这里比较推荐以下几本书:

  • 《白帽子讲Web安全》
  • 《Web安全深度剖析》
  • 《Web安全攻防 渗透测试实战指南》

第二阶段:学习基础知识

在这个阶段,你已经对网络安全有了基本的了解。如果你认真看完了上面推荐的书籍和课程,相信你已经在理论上明白了上面是sql注入,什么是xss攻击,对burp、msf、cs等安全工具也掌握了基础操作。这个时候最重要的就是开始打地基!

所谓的“打地基”其实就是系统化的学习计算机基础知识。而想要学习好网络安全,首先要具备5个基础知识模块:

学习这些基础知识有什么用呢?

计算机各领域的知识水平决定你渗透水平的上限。

  • 比如:你编程水平高,那你在代码审计的时候就会比别人强,写出的漏洞利用工具就会比别人的好用;
  • 比如:你数据库知识水平高,那你在进行SQL注入攻击的时候,你就可以写出更多更好的SQL注入语句,能绕过别人绕不过的WAF;
  • 比如:你网络水平高,那你在内网渗透的时候就可以比别人更容易了解目标的网络架构,拿到一张网络拓扑就能自己在哪个部位,拿到以一个路由器的配置文件,就知道人家做了哪些路由;
  • 再比如你操作系统玩的好,你提权就更加强,你的信息收集效率就会更加高,你就可以高效筛选出想要得到的信息

这些基础该学到什么程度呢?

计算机各领域的知识水平决定你渗透水平的上限,但是零基础并不是要把上面的全部都学的很好再去搞渗透,那不仅会劝退大部分人,而且像我前面说的深度学习很容易学的囫囵吞枣,最后反而竹篮打水一场空

作为初学者,可以先学习基础。比如你先学一个编程语言的基础,用PHP做例子,你起码要懂if else这些、连接数据库;比如学数据库,用MySQL做例子,那至少也是要会增删改查、子查询这几个操作;网络的话比较难,也是很抽象的,你做外网的渗透,至少要懂基础的http协议,知道端口是什么,知道网站是怎么架设起来的;操作系统的基础相对比较好学,主要是各种命令的作用,各种软件的安装和使用

学习书籍和资源推荐:

《HTTP权威指南》

《Python核心编程》

《PHP和MySQL Web开发》

《JavaScript高级程序设计》

Damn Vulnerable Web Application
Audi-1/sqli-labs
BUUCTF
bugku
网络信息安全攻防平台

第三阶段:实战操作

1.挖SRC

挖SRC的目的主要是讲技能落在实处,学习网络安全最大的幻觉就是觉得自己什么都懂了,但是到了真的挖漏洞的时候却一筹莫展,而SRC是一个非常好的技能应用机会

SRC平台:

SRC平台合集

2.从技术分享帖(漏洞挖掘类型)学习

观看学习近十年所有0day挖掘的帖,然后搭建环境,去复现漏洞,去思考学习笔者的挖洞思维,培养自己的渗透思维!

安全大佬博客:

Sec-News
李劼杰的博客
Yaseng 博客
离别歌
Lcy’s Blog
hackfun
信安之路
蓝骑兵

书籍推荐:

  • 《WEB之困-现代WEB应用安全指南》
  • 《内网安全攻防渗透测试安全指南》
  • 《Metasploit渗透测试魔鬼训练营》
  • 《SQL注入攻击与防御》
  • 《黑客攻防技术宝典-Web实战篇(第2版)》

到这一步,再加上之后对挖掘漏洞的技术多加练习与积累实战经验,基本就可以达到安全工程师的级别

所有资料共87.9G,朋友们如果有需要全套《网络安全入门+进阶学习资源包》,可以扫描下方CSDN官方合作二维码免费领取(如遇扫码问题,可以在评论区留言领取哦)~

网络安全学习路线&学习资源

在这里插入图片描述

如有侵权,请联系删除。

Logo

openEuler 是由开放原子开源基金会孵化的全场景开源操作系统项目,面向数字基础设施四大核心场景(服务器、云计算、边缘计算、嵌入式),全面支持 ARM、x86、RISC-V、loongArch、PowerPC、SW-64 等多样性计算架构

更多推荐