网络安全的方向选择与入门?

作为一个工作十余年,有丰富[Web安全]攻防、渗透领域实战经验的老鸟,由于我之前写了不少网络安全技术相关的文章和回答,不少读者朋友知道我是从事网络安全相关的工作,于是经常有人私信问我:

  • 我刚[入门网]络安全,该怎么学?
  • 要学哪些东西?
  • 有哪些方向?
  • 怎么选?
  • 这一行职业前景如何?

不同于Java、C/C++等后端开发岗位有非常明晰的学习路线,网路安全更多是靠自己摸索,要学的东西又杂又多,难成体系。
img
常读我文章的朋友知道,我很少去谈到职场、面试这些方面的内容。主要是考虑到现在大家的压力已经很大,节奏很快,所以尽量写一些轻快的内容。不过随着越来越多的人问我上面这些问题,今天就专门写一篇来摆一摆这个龙门阵。

近几年,随着网络安全被列为国家安全战略的一部分,这个曾经细分的领域发展提速了不少,除了一些传统安全厂商以外,一些互联网大厂也都纷纷加码了在这一块的投入,随之而来的吸引了越来越多的新鲜血液不断涌入。

一、网络安全分支

其实在网络安全这个概念之上,还有一个更大的概念:信息安全。本文不去探讨二者在学术划分上的区别,如无特殊说明,文中将其视为一个概念,我们来看下实际工作方向上,有哪些细分路线。

img

在这个圈子技术门类中,工作岗位主要有以下三个方向:

  • 安全研发
  • 安全研究:二进制方向
  • 安全研究:网络渗透方向

下面逐一说明一下。

1.1、安全研发

安全行业的研发岗主要有两种分类:

  • 与安全业务关系不大的研发岗位
  • 与安全业务紧密相关的研发岗位

你可以把网络安全理解成电商行业、教育行业等其他行业一样,每个行业都有自己的软件研发,网络安全作为一个行业也不例外,不同的是这个行业的研发就是开发与网络安全业务相关的软件。

既然如此,那其他行业通用的岗位在安全行业也是存在的,前端、后端、大数据分析等等,也就是属于上面的第一个分类,与安全业务关系不大的类型。这里我们重点关注下第二种,与安全业务紧密相关的研发岗位。

这个分类下面又可以分为两个子类型:

  • 做安全产品开发,做防
  • 做安全工具开发,做攻

安全行业要研发的产品,主要(但不限于)有下面这些:

  • 防火墙、IDS、IPS
  • WAF(Web网站应用防火墙)
  • 数据库网关
  • NTA([网络流量分析]))
  • SIEM(安全事件分析中心、[态势感知])
  • 大数据安全分析
  • EDR(终端设备上的安全软件)
  • DLP(数据泄漏防护)
  • [杀毒软件]
  • 安全检测沙箱

总结一下,安全研发的产品大部分都是用于检测发现、抵御安全攻击用的,涉及终端侧(PC电脑、手机、网络设备等)、网络侧。

开发这些产品用到的技术主要以C/C++、Java、Python三大技术栈为主,也有少部分的GoLang、Rust。

安全研发岗位,相对其他两个方向,对网络安全技术的要求要低一些(只是相对,部分产品的研发对安全技能要求并不低),甚至我见过不少公司的研发对安全一无所知。在这种情况下,如果除了基本的开发功底以外,对网络安全技术有所了解,自然会是你面试这些岗位时的加分项。

安全研发岗位,除了通用开发技能的要求以外,可以重点关注一下下面这些技术:

img

上面列举的只是最直接相关的部分,还需要有了解更多安全技术才能更好的开发产品,继续往下看。

1.2、二进制安全

二进制安全方向,这是安全领域两大技术方向之一。

这个方向主要涉及到软件漏洞挖掘、逆向工程、病毒木马分析等工作,涉及操作系统内核分析、调试与反调试、反病毒等技术。因为经常都是与二进制的数据打交道,所以久而久之用二进制安全来统称这个方向。

这个方向的特点是:需要耐得住寂寞。

比不上安全研发可以有实实在在的产品输出,也比不上网络渗透方向听起来的狂拽炫酷,这个方向更多时间是在默默的分析和研究。

以漏洞挖掘为例,光是学习五花八门的攻击手法就需要花不少的时间。在这个领域,为了研究一个问题,可能花费数月甚至数年时间,这绝非一般人能坚持下来的。不仅如此,不是勤奋就可以成功,更多还要靠天分。

像腾讯几大安全实验室的掌门人,业界知名的TK教主、吴石这些人物,他们已经深谙漏洞挖掘的奥义,并将这门绝技融会贯通,做个梦都能想到新的玩法。不过像这样的天才实在是少之又少,绝大多数人都无法企及。

如果说程序员是苦逼的话,那二进制安全研究就是苦逼Plus。

如果看了这些你还是有勇气进入这个领域,那下面这些东西是你需要学的:

img

这个方向比起安全研发,不仅技术难度更大,提供这些岗位的公司也很少,且基本上分布于北上广深几个一线城市。

1.3、网络渗透

这个方向更符合于大部分人对“黑客”的认知,他们能够黑手机、黑电脑、黑网站、黑服务器、黑内网,万物皆可黑。

相比二进制安全方向,这个方向初期更容易入门一些,掌握一些基本技术,拿起各种现成的工具就可以开黑了。

不过,要想从[脚本小子变成[黑客大神],这个方向越往后,需要学习和掌握的东西就多了:

img

网络渗透的方向更偏向于“实战”,因此对技术在广度上有更高的要求,从网络硬件设备、[网络通信协议]、网络服务(web、邮件、文件、数据库等)、到操作系统、攻击手法等等都需要了解。更偏向于一个全能型的计算机专家,将各种技术融会贯通,以用于“实战”。

网络渗透方向的工作有下面几个方向:

  • 安全服务,俗称乙方,这是最主要的一个方向,为甲方公司提供安全能力支持,如[渗透测试],产品安全检测等。
  • 安全能力建设,俗称甲方,国内稍微有点规模的公司都有自己的SRC(安全应急响应中心),也就是有自己的安全团队。
  • 国家队:你懂的

二、学习路线

上面说完了三个大的技术方向后,下面来聊聊该怎么上路呢?下面说说我的看法。

首先别想分方向,先打好基础!

第一步:[计算机基础]

这第一步,其实跟网络安全关系都不太大,而是进入IT领域的任何一个人都要掌握的基础能力。下面五大课程,是大学老师当年教给我们的,不管你是什么技术方向最好都好好学的技术,如今看来,仍然不过时:

  • [计算机网络]
  • 计算机组成原理
  • 操作系统
  • 算法与数据结构
  • 数据

这每一门课程其实都内有乾坤,基本都不能做到一次学习就能掌握,而是伴随每个人的职业生涯,不同的技术阶段都会有不一样的认识和感受。

具体学起来建议参考[敏捷开发],不断迭代:有一个粗略的认识->有了进一步的认识->彻底掌握->温故而知新。不用纠缠于把一门课程全部学完学懂才进入下一门课程。

第二步:编程能力

有了上面的一些基本功后,这个时候就需要动手,来写点代码,锤炼一下编程的功底。

下面三项,是安全行业的从业者都最好能掌握的语言:

  • [Shell脚本]:掌握常用的Linux命令,能编写简单的Shell脚本,处理一些简单的事务。
  • C语言(C++可选):C语言没有复杂的特性,是现代编程语言的祖师爷,适合编写底层软件,还能帮助你理解内存、算法、操作系统等计算机知识,建议学一下。
  • Python:C语言帮助你理解底层,Python则助你编写网络、爬虫、数据处理、图像处理等功能性的软件。是程序员,尤其是黑客们非常钟爱的编程语言,不得不学。

第三步:安全初体验

有了前面两步的打底,是时候接触一些网络安全的技术了,刚刚开始这个阶段,仍然不要把自己圈起来只学某一个方向的技术。这个阶段,我的建议是:但当涉猎,[见往事耳]。

[网络协议]攻击、Web服务攻击、浏览器安全、漏洞攻击、逆向破解、工具开发都去接触一下,知道这是做什么的,在这个过程中去发现自己的兴趣,让自己对网络安全各种领域的技术都有一个初步的认识。

第四步:分方向

在第三步中,慢慢发现自己的兴趣点,是喜欢做各种工具的开发,还是喜欢攻破网站,还是痴迷于主机电脑的攻击···

这个时候就可以思考自己后面的方向,然后精力开始聚焦在这个方向上,通过上面思维导图中各自方向的技术去持续深耕,成为某一个领域的大拿。

三、学习方法

上面介绍了技术分类和学习路线,这里来谈一下学习方法

  • 看书学习,这是最最基础的
  • 实际动手,开发路线需要多写代码,阅读优秀开源代码,二进制路线多分析样本,编写EXP等等,渗透测试多拿网站练手(合法方式)等
  • 打CTF,多参与一些网络安全比赛,接近实战的环境下锻炼动手能力
  • 混圈子,多混一些安全大牛出没的社群、社区、论坛,掌握行业信息,了解最新技术变化趋势(高清版思维导图有)

四、总结

以上就是我对刚入行网络安全的朋友的一些个人的建议,最后有一点需要说明一下:

上面列举到的不同方向的技术不是严格意义独立的,相反,很多时候是相辅相成,需要结合起来,融会贯通。

每个人的认知是有限的,我也不例外。本篇回答只是我的一家之言,建议大家多看一些人的总结和经验,横向对比,兼听则明,偏听则暗。

如果你想通过自学进入网络安全这一行,甚至拿到月入30000+这个薪资,我可以把我自己整理收藏的这些教程分享给你,**里面不仅有web安全,还有渗透测试等等内容,包含电子书、面试题、pdf文档、视频以及相关的课件笔记,**大部分我都看过,感觉还不错,如果需要的话可以评论区告诉我。

img

img

img

img
如果觉得有帮助的话,可以帮我点赞收藏一下,写的不对或不清楚的地方,也欢迎大家在评论区指出,谢谢!

文章中展示的学习资料已经上传CSDN,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 对于计算机专业的应届生来说,选择前端或后端工作方向都是可以的。具体选择哪个方向,可以根据自己的兴趣和优势来决定。 前端开发指的是网站或应用的用户界面部分的开发,主要使用的技术包括 HTML、CSS 和 JavaScript 等。前端开发工程师的工作内容是设计和开发用户界面,负责网站或应用的外观、布局和交互,使之能够流畅地运行在各种终端设备上。 后端开发指的是网站或应用的服务端部分的开发,主要使用的技术包括服务器端编程语言、数据库技术等。后端开发工程师的工作内容是负责网站或应用的后台逻辑、数据处理和存储,使之能够提供所需的服务和数据。 总的来说,前端开发更加注重用户体验,需要具备良好的视觉设计能力和用户交互设计能力;而后端开发则更加注重系统的稳定性和性能,需要具备良好的算法能力和系统架构能力。因此,应届生在选择工作方向时,可以根据自己的兴趣和优势来决定是前 ### 回答2: 计算机专业应届生毕业后的工作方向选择,前端和后端都是值得考虑的。前端开发主要涉及用户界面设计和开发,负责实现网页、应用程序的可视化部分,会用到HTML、CSS、JavaScript等技术。后端开发则主要负责服务器端的应用程序开发,处理与数据库的交互和数据逻辑等方面,会涉及到Java、Python、C#等编程语言。选择前端还是后端,需要根据个人兴趣、个人能力以及就业市场需求等进行全面考虑。 前端开发的就业前景广阔,随着互联网的发展,对于用户体验的要求越来越高,前端开发岗位需求增长迅速。前端开发也更加注重创意和艺术,适合喜欢设计和用户交互的人。而且前端开发相对来说入门门槛较低,容易上手。 后端开发则需要对编程语言和算法有更深入的理解和掌握,需要善于处理各种复杂的后台逻辑。后端开发在互联网企业和大型软件开发公司都有巨大的就业机会,对于技术要求较高的人而言是更好的选择。 综上所述,选择前端还是后端取决于个人兴趣和技能,以及就业市场需求。无论选择哪个方向,都需要不断学习和提升自己的技能,适应行业的变化和发展。 ### 回答3: 计算机专业应届生毕业后,在选择前端还是后端工作方向时,需要考虑个人的兴趣、能力以及市场需求等因素。 前端开发主要涉及网站或应用程序的用户界面设计和实现。前端工程师需要具备一定的艺术和设计素养,熟悉各种前端技术如HTML、CSS、JavaScript等。前端工作相对直观,可以通过编写代码实现用户界面,并与用户进行直接互动。同时,前端工作也负责优化用户体验,在用户界面设计方面有更大的发挥空间。 后端开发主要涉及服务器端程序和数据库的开发和维护。后端工程师需要具备扎实的编程基础,熟悉多种编程语言如Java、Python、PHP等,并了解数据库和网络等相关知识。后端工作的重点是处理数据和逻辑,确保系统的稳定性和安全性。后端工程师对系统的整体架构和性能优化有更深入的了解。 在做出选择时,可以根据自己的兴趣和特长来决定。如果擅长设计、对用户交互和界面有浓厚兴趣,那么前端工作可能更适合;如果喜欢编程、善于处理逻辑和算法问题,那么后端工作可能更适合。 另外,需要考虑就业市场对这两个领域的需求情况。目前来看,前端开发岗位的需求较为旺盛,尤其是移动互联网行业,但竞争也相对更激烈。后端开发岗位虽然需求相对较少,但相对稳定,行业广泛,发展空间也较为广阔。 因此,选择前端还是后端工作方向,需要根据个人的兴趣和能力,以及就业市场的需求情况来综合考虑,并在不断学习和实践中逐渐发现自己的路向。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值