随着网络安全被列为国家安全战略的一部分,这个曾经细分的领域发展提速了不少,除了一些传统安全厂商以外,一些互联网大厂也都纷纷加码了在这一块的投入,随之而来的吸引了越来越多的新鲜血液不断涌入。
不同于Java、C/C++等后端开发岗位有非常明晰的学习路线,网路安全更多是靠自己摸索,要学的东西又杂又多,难成体系。
网络安全分支
其实在网络安全这个概念之上,还有一个更大的概念:信息安全。
工作岗位主要有以下
网络安全工程师
信息安全工程师
风险评估工程师
应急响应工程师
o系统集成工程师
等保测试工程师
安全运维工程师
大数据安全工程师
安全研究员
滲透测试工程师
代码审计工程师
安全研发
安全行业的研发岗主要有两种分类:
与安全业务关系不大的研发岗位
与安全业务紧密相关的研发岗位
你可以把网络安全理解成电商行业、教育行业等其他行业一样,每个行业都有自己的软件研发,网络安全作为一个行业也不例外,不同的是这个行业的研发就是开发与网络安全业务相关的软件。
既然如此,那其他行业通用的岗位在安全行业也是存在的,前端、后端、大数据分析等等,也就是属于上面的第一个分类,与安全业务关系不大的类型。这里我们重点关注下第二种,与安全业务紧密相关的研发岗位。
这个分类下面又可以分为两个子类型:
做安全产品开发,做防
做安全工具开发,做攻
安全行业要研发的产品,主要(但不限于)有下面这些:
防火墙、IDS、IPS
WAF(Web网站应用防火墙)
数据库网关
NTA(网络流量分析)
SIEM(安全事件分析中心、态势感知)
大数据安全分析
EDR(终端设备上的安全软件)
DLP(数据泄漏防护)
杀毒软件
安全检测沙箱
开发这些产品用到的技术主要以C/C++、Java、Python三大技术栈为主,也有少部分的GoLang、Rust。
安全研发岗位,相对其他两个方向,对网络安全技术的要求要低一些(只是相对,部分产品的研发对安全技能要求并不低),甚至我见过不少公司的研发对安全一无所知。
在这种情况下,如果除了基本的开发功底以外,对网络安全技术有所了解,自然会是你面试这些岗位时的加分项。
安全研发岗位,除了通用开发技能的要求以外,可以重点关注一下下面这些技术:
上面列举的只是最直接相关的部分,还需要有了解更多安全技术才能更好的开发产品,继续往下看。
二进制安全
二进制安全方向,这是安全领域两大技术方向之一。
这个方向主要涉及到软件漏洞挖掘、逆向工程、病毒木马分析等工作,涉及操作系统内核分析、调试与反调试、反病毒等技术。
因为经常都是与二进制的数据打交道,所以久而久之用二进制安全来统称这个方向。
这个方向的特点是:需要耐得住寂寞。
比不上安全研发可以有实实在在的产品输出,也比不上网络渗透方向听起来的狂拽炫酷,这个方向更多时间是在默默的分析和研究。
以漏洞挖掘为例,光是学习五花八门的攻击手法就需要花不少的时间。在这个领域,为了研究一个问题,可能花费数月甚至数年时间,这绝非一般人能坚持下来的。不仅如此,不是勤奋就可以成功,更多还要靠天分。
如果看了这些你还是有勇气进入这个领域,那下面这些东西是你需要学的:
这个方向比起安全研发,不仅技术难度更大,提供这些岗位的公司也很少,且基本上分布于北上广深几个一线城市。
网络渗透
这个方向更符合于大部分人对“黑客”的认知,他们能够黑手机、黑电脑、黑网站、黑服务器、黑内网,万物皆可黑。
相比二进制安全方向,这个方向初期更容易入门一些,掌握一些基本技术,拿起各种现成的工具就可以开黑了。
不过,要想从脚本小子变成黑客大神,这个方向越往后,需要学习和掌握的东西就多了:
网络渗透的方向更偏向于“实战”,因此对技术在广度上有更高的要求,从网络硬件设备、网络通信协议、网络服务(web、邮件、文件、数据库等)、到操作系统、攻击手法等等都需要了解。更偏向于一个全能型的计算机专家,将各种技术融会贯通,以用于“实战”。
网络渗透方向的工作有下面几个方向:
安全服务,俗称乙方,这是最主要的一个方向,为甲方公司提供安全能力支持,如渗透测试,产品安全检测等。
安全能力建设,俗称甲方,国内稍微有点规模的公司都有自己的SRC(安全应急响应中心),也就是有自己的安全团队。
国家队:你懂的
学习路线
上面说完了三个大的技术方向后,下面来聊聊该怎么入手呢?下面说说我的看法。
首先别想分方向,先打好基础!可以参考下面这个学习路线(高清可展开脑图移步文末)
入门的第一步是系统化的学习计算机基础知识,也就是学习基础知识模块:操作系统、协议/网络、数据库、开发语言、常用漏洞原理。基础知识学完之后,就要进行实操了。
然后就进入到了渗透阶段:
- SQL注入的渗透与防御
- XSS相关渗透与防御
- 上传验证渗透与防御
- 文件包含渗透与防御
- CSRF渗透与防御
- SSRF渗透与防御
- XXE渗透与防御
- 远程代码执行渗透与防御
- 反序列化渗透与防御
- 逻辑漏洞
- 暴力拆解与防御
- Redis未授权访问漏洞
- AWWS漏洞扫描
- Appscan漏洞扫描
- Nessus漏洞扫描
- MSF-Metasploit Framework
- 社会工程学
- APP渗透与预防
- 系统权限提升渗透与防御
- DOS与DDOS渗透与防御
- 内网相关渗透与防御
- 无线安全相关渗透与防御
- 木马免杀问题与防御
- vulnhub靶场实战系列
- Kali高级渗透测试
掌握常见漏洞的原理、使用、防御等知识。
Web渗透阶段还是需要掌握一些必要的工具。
主要要掌握的工具和平台:
- burp
- AWVS
- Appscan
- Nessus
- sqlmap
- nmap
- shodan
- fofa
代理工具:
- ssrs
- hydra
- medus
- Airspoof
以上工具的练习完全可以利用上面的开源靶场去练习,足够了。
以上这些基本三四个月就可以学完了,之后就可以进行学习安全服务类:
- 风险评估
- 等级保护
- 安全咨询
- 安全法律法规解读
- 还可以再学习CTF技术。
通过大概三个月认真的学习上面总结的知识绝对可以入门并达到企业的初级用人水平,问题不大,至少可以做个基本都网络安全工程师,但是如果你想要更高的工资更好的待遇你就要做到学无止尽。
从时代发展的角度看,网络安全的知识是学不完的,而且以后要学的会更多,同学们要摆正心态,既然选择入门网络安全,就不能仅仅只是入门程度而已,能力越强机会才越多。
因为入门学习阶段知识点比较杂,所以上面就写的比较笼统,需要相关资料也可以找我要,我这里也整理了一份超全的资料笔记。如果有不懂的地方可以找我咨询,想要进入行业成为行业大佬欢迎找我,我保证知无不言言无不尽。
学习方法
上面介绍了技术分类和学习路线,这里来谈一下学习方法
看书学习,这是最最基础的
实际动手,开发路线需要多写代码,阅读优秀开源代码,二进制路线多分析样本,编写EXP等等,渗透测试多拿网站练手(合法方式)等
打CTF,多参与一些网络安全比赛,接近实战的环境下锻炼动手能力
混圈子,多混一些安全大牛出没的社群、社区、论坛,掌握行业信息,了解最新技术变化趋势
上面这份完整版的网安学习资料已经上传,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】