因为我以前写了很多网络安全技术相关的故事文章,很多读者朋友知道我是从事网络安全相关的工做,因而常常有人在微信里问我:前端
我刚入门网络安全,该怎么学?要学哪些东西?有哪些方向?怎么选?程序员
不一样于Java、C/C++等后端开发岗位有很是明晰的学习路线,网路安全更可能是靠本身摸索,要学的东西又杂又多,难成体系。web
常读我文章的朋友知道,个人文章基本以故事为载体的技术输出为主,不多去谈到职场、面试这些方面的内容。主要是考虑到如今你们的压力已经很大,节奏很快,公众号上是让你们放松的地方,尽可能写一些轻快的内容。不过随着愈来愈多的人问我上面这些问题,今天就专门写一篇来摆一摆这个龙门阵。面试
近几年,随着网络安全被列为国家安全战略的一部分,这个曾经细分的领域发展提速了很多,除了一些传统安全厂商之外,一些互联网大厂也都纷纷加码了在这一块的投入,随之而来的吸引了愈来愈多的新鲜血液不断涌入。算法
网络安全分支
其实在网络安全这个概念之上,还有一个更大的概念:信息安全。本文不去探讨两者在学术划分上的区别,如无特殊说明,文中将其视为一个概念,咱们来看下实际工做方向上,有哪些细分路线。数据库
在这个圈子技术门类中,工做岗位主要有如下三个方向:编程
- 安全研发
- 安全研究:二进制方向
- 安全研究:网络***方向
下面逐一说明一下。后端
安全研发
安全行业的研发岗主要有两种分类:浏览器
- 与安全业务关系不大的研发岗位
- 与安全业务紧密相关的研发岗位
你能够把网络安全理解成电商行业、教育行业等其余行业同样,每一个行业都有本身的软件研发,网络安全做为一个行业也不例外,不一样的是这个行业的研发就是开发与网络安全业务相关的软件。安全
既然如此,那其余行业通用的岗位在安全行业也是存在的,前端、后端、大数据分析等等,也就是属于上面的第一个分类,与安全业务关系不大的类型。这里咱们重点关注下第二种,与安全业务紧密相关的研发岗位。
这个分类下面又能够分为两个子类型:
- 作安全产品开发,作防
- 作安全工具开发,作攻
安全行业要研发的产品,主要(但不限于)有下面这些:
- 防火墙、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,多参与一些网络安全比赛,接近实战的环境下锻炼动手能力
- 混圈子,多混一些安全大牛出没的社群、社区、论坛,掌握行业信息,了解最新技术变化趋势(高清版思惟导图有)
- 关注微信公众号【编程技术宇宙】,干货技术,有趣故事一网打尽,多多分享文章就能够积累经验值哦
总结
以上就是我对刚入行网络安全的朋友的一些我的的建议,最后有一点须要说明一下:
上面列举到的不一样方向的技术不是严格意义独立的,相反,不少时候是相辅相成,须要结合起来,融会贯通。
每一个人的认知是有限的,我也不例外。本文只是个人一家之言,建议你们多看一些人的总结和经验,横向对比,兼听则明,偏听则暗。
Tips
想获取上面思惟导读完整高清版,能够在公众号里回复「安全」自动获取。