如何入门网络安全_网络安全自学
由于我之前写了不少网络安全技术相关的故事文章,不少读者朋友知道我是从事网络安全相关的工作,于是经常有人在微信里问我:
我刚入门网络安全,该怎么学?要学哪些东西?有哪些方向?怎么选?
不同于Java、C/C++等后端开发岗位有非常明晰的学习路线,网路安全更多是靠自己摸索,要学的东西又杂又多,难成体系。
我知道,常阅读我文章的朋友们明白,我主要是通过故事来传递技术知识,很少涉及职场或面试等话题。这是因为我认为,我们现在的生活压力已经很大,节奏也很快,通过我的公众号,我希望能让大家放松一下,所以尽可能地写一些轻松愉快的内容。但由于越来越多的人向我提问关于职场和面试的问题,我决定今天专门写一篇文章来解答这些问题。
近年来,随着网络安全被视为国家安全战略的重要组成部分,这个曾经的小众领域正在急速发展。除了一些传统的安全公司之外,许多互联网巨头也在这个领域加大了投入,吸引了大量新血液的加入。
网络安全分支
实际上,网络安全只是一个更大概念的一部分:信息安全。在这篇文章中,我们并不打算深入讨论两者之间在学术上的差异。除非有特殊说明,否则在文中,我们将视网络安全和信息安全为同一概念,并探讨在实际工作方向上有哪些细分路线。
在这个圈子技术门类中,工作岗位主要有以下三个方向:
- 安全研发
- 安全研究:二进制方向
- 安全研究:网络渗透方向
下面逐一说明一下。
安全研发
安全行业的研发岗主要有两种分类:
- 与安全业务关系不大的研发岗位
- 与安全业务紧密相关的研发岗位
网络安全可以被看作与电商行业、教育行业等其他行业一致,每个行业都有自己的软件开发需要,同样地,网络安全作为一个专门的行业,也有自己针对网络安全相关业务的软件开发需求。
既然这样,那么在其他行业普遍存在的职位,在网络安全行业中也是能找到的,比如前端开发、后端开发、大数据分析等,这些属于上文提到的第一类,与网络安全业务关系不大的岗位。下面我们将重点讨论第二类,即与网络安全业务紧密相连的研发职位。
这个分类下面又可以分为两个子类型:
- 做安全产品开发,做防
- 做安全工具开发,做攻
安全行业要研发的产品,主要(但不限于)有下面这些:
- 防火墙、IDS、IPS
- WAF(Web网站应用防火墙)
- 数据库网关
- NTA(网络流量分析)
- SIEM(安全事件分析中心、态势感知)
- 大数据安全分析
- EDR(终端设备上的安全软件)
- DLP(数据泄漏防护)
- 杀毒软件
- 安全检测沙箱
总结一下,安全研发的产品大部分都是用于检测发现、抵御安全攻击用的,涉及终端侧(PC电脑、手机、网络设备等)、网络侧。
开发这些产品用到的技术主要以C/C++、Java、Python三大技术栈为主,也有少部分的GoLang、Rust。
安全研发岗位,相对其他两个方向,对网络安全技术的要求要低一些(只是相对,部分产品的研发对安全技能要求并不低),甚至我见过不少公司的研发对安全一无所知。在这种情况下,如果除了基本的开发功底以外,对网络安全技术有所了解,自然会是你面试这些岗位时的加分项。
安全研发岗位,除了通用开发技能的要求以外,可以重点关注一下下面这些技术:
上面列举的只是最直接相关的部分,还需要有了解更多安全技术才能更好的开发产品,继续往下看。
二进制安全
二进制安全领域,是网络安全两大核心技术方向之一。
这个领域主要涉及到软件漏洞的发掘、逆向工程以及病毒和木马的分析等任务,其中包含操作系统内核分析、调试与反调试、反病毒等技术。由于这个领域经常处理二进制数据,因此最终以二进制安全来概括这个领域。
这个方向的特点是:需要耐得住寂寞。
比不上安全研发可以有实实在在的产品输出,也比不上网络渗透方向听起来的狂拽炫酷,这个方向更多时间是在默默的分析和研究。
以漏洞挖掘为例,仅仅学习各种复杂的攻击策略就需要投入大量的时间。在这个领域,你可能要花费数月甚至数年的时间去研究一个问题,这样的坚持对普通人来说几乎是不可能的。而且,成功并非只靠努力,更多的还需要依赖于天赋。
比如腾讯的几大安全实验室的领导者,包括业界知名的TK教主、吴石等人,他们已经深入理解了漏洞挖掘的秘密,并且全面掌握了这门技术,甚至在梦中也能想出新的应用方法。但是,像他们这样的天才实在太少了,绝大部分人可能都无法达到这样的高度。
如果说程序员是苦逼的话,那二进制安全研究就是苦逼Plus。
如果看了这些你还是有勇气进入这个领域,那下面这些东西是你需要学的:
这个方向比起安全研发,不仅技术难度更大,提供这些岗位的公司也很少,且基本上分布于北上广深几个一线城市。
网络渗透
这个领域更接近大多数人对“黑客”的理解,他们可以入侵手机、电脑、网站、服务器、内部网络,几乎没有什么是他们不能入侵的。
相比于二进制安全领域,这个领域对初学者来说更加友好。只要掌握一些基本技术,使用现有的工具,就可以开始实施黑客行为。
然而,如果想从一个编写脚本的小白变成黑客高手,这个领域越往深入,需要学习和掌握的知识就越多:
网络渗透这个领域更加倾向于“实战”,因此对技术广度的需求较高,涵盖了从网络硬件设备、网络通信协议、网络服务(包括web、邮件、文件、数据库等)、操作系统到攻击手法等等。它更像是一个全能型的计算机专家,将各种技术熟练掌握并融会贯通,为“实战”做好准备。
网络渗透方向的工作有下面几个方向:
安全服务,也被广泛称为乙方,这是主要的一个领域,他们为甲方公司提供各种安全技术支持,如渗透测试,产品安全检测等。另一方面,安全能力建设,通常被称为甲方,国内稍大规模的公司都有自己的SRC(安全应急响应中心),也就是说,他们拥有自己的安全团队。至于国家队:你知道的。
学习路线
上面说完了三个大的技术方向后,下面来聊聊该怎么上路呢?下面说说我的看法。
首先别想分方向,先打好基础!
第一步:计算机基础
实际上,这第一步并不直接关联网络安全,反而是任何想要进入IT领域的人都应该掌握的基础技能。以下五门课程是大学教师当年强调所有技术方向的学生都应认真学习的内容,如今看来,它们仍然是时代所需:
- 计算机网络
- 计算机组成原理
- 操作系统
- 算法与数据结构
- 数据库
实际上,每一门课程都有着深厚的内涵,基本上不能期待一次学习就可以完全掌握,而需要随着职业生涯的发展,根据不同的技术阶段来重新理解和感受。
具体的学习方法,我建议你参考敏捷开发的方式,进行持续的迭代:初步了解->深化认识->完全掌握->反复温习以获得新的理解。不必纠结于要把一门课程全部学透才能开始下一门课程。
第二步:编程能力
有了上面的一些基本功后,这个时候就需要动手,来写点代码,锤炼一下编程的功底。
下面三项,是安全行业的从业者都最好能掌握的语言:
- Shell脚本
掌握常用的Linux命令,能编写简单的Shell脚本,处理一些简单的事务。
- C语言(C++可选)
C语言没有复杂的特性,是现代编程语言的祖师爷,适合编写底层软件,还能帮助你理解内存、算法、操作系统等计算机知识,建议学一下。
- Python
C语言帮助你理解底层,Python则助你编写网络、爬虫、数据处理、图像处理等功能性的软件。是程序员,尤其是黑客们非常钟爱的编程语言,不得不学。
第三步:安全初体验
在完成前两步基础工作后,现在是时候接触一些网络安全的技术了。但在刚开始这个阶段,我建议你不要只局限于学习某一个方向的技术。在这个阶段,我的建议是**:广泛涉猎,知识面要广。**
比如网络协议攻击、Web服务攻击、浏览器安全、漏洞攻击、逆向激活成功教程、工具开发等,都要去了解和学习,了解它们各自的功能和用途。在这个过程中,你可能会发现自己的兴趣所在,并对网络安全各种领域的技术有一个初步的认识。
第四步:分方向
在进入第三阶段时,你可能会逐渐发现自己的兴趣所在,是喜欢开发各种工具,还是喜欢攻破网站,或是对主机电脑的攻击有着特别的痴迷···
在这个阶段,你可以开始思考自己未来的发展方向,并把精力集中在这个方向上。通过不断深入学习和理解思维导图中各自方向的技术,你可以成为某一领域的专家。
学习方法
上面介绍了技术分类和学习路线,这里来谈一下学习方法
- 看书学习,这是最最基础的
- 实际动手,开发路线需要多写代码,阅读优秀开源代码,二进制路线多分析样本,编写EXP等等,渗透测试多拿网站练手(合法方式)等
- 打CTF,多参与一些网络安全比赛,接近实战的环境下锻炼动手能力
- 混圈子,多混一些安全大牛出没的社群、社区、论坛,掌握行业信息,了解最新技术变化趋势(高清版思维导图有)
如何入门学习网络安全【护网】
【----帮助网安学习,以下所有学习资料文末免费领取!----】
> ① 网安学习成长路径思维导图
> ② 60+网安经典常用工具包
> ③ 100+SRC漏洞分析报告
> ④ 150+网安攻防实战技术电子书
> ⑤ 最权威CISSP 认证考试指南+题库
> ⑥ 超1800页CTF实战技巧手册
> ⑦ 最新网安大厂面试题合集(含答案)
> ⑧ APP客户端安全检测指南(安卓+IOS)
大纲
首先要找一份详细的大纲。
学习教程
第一阶段:零基础入门系列教程
该阶段学完即可年薪15w+
第二阶段:技术入门
弱口令与口令爆破
XSS漏洞
CSRF漏洞
SSRF漏洞
XXE漏洞
SQL注入
任意文件操作漏洞
业务逻辑漏洞
该阶段学完年薪25w+
阶段三:高阶提升
反序列化漏洞
RCE
综合靶场实操项目
内网渗透
流量分析
日志分析
恶意代码分析
应急响应
实战训练
该阶段学完即可年薪30w+
面试刷题
最后,我其实要给部分人泼冷水,因为说实话,上面讲到的资料包获取没有任何的门槛。
但是,我觉得很多人拿到了却并不会去学习。
大部分人的问题看似是“如何行动”,其实是“无法开始”。
几乎任何一个领域都是这样,所谓“万事开头难”,绝大多数人都卡在第一步,还没开始就自己把自己淘汰出局了。
如果你真的确信自己喜欢网络安全/黑客技术,马上行动起来,比一切都重要。
资料领取
上述这份完整版的网络安全学习资料已经上传网盘,朋友们如果需要可以微信扫描下方二维码 即可自动领取↓↓↓
或者
【点此链接】领取