老实说,学习黑客攻防知识还是挺复杂的。</p>
攻防?</p>
明明林枫是要进攻,这里怎么涉及到“防”了。</p>
虽然攻防不能说是一体的。</p>
但了解攻击当然得先知道防御。</p>
很多黑客其实本质上也是网络安全专家。</p>
可惜了,正邪之分,存乎一心。</p>
想要更好的理解进攻,就得先学会防守。</p>
而且是重头学一遍,林枫先前掌握的那些防守技巧还不够。</p>
也正因此整个过程很复杂。</p>
好吧,不是一般意义的复杂,而是非常之复杂。</p>
你得懂得跟计算机和网路相关的很多细碎但基础的知识。</p>
要熟练掌握操作系统的工作原理及结构;</p>
要熟悉tcp/ip协议和网络协议栈;</p>
要理解路由、交换、网络拓扑背后的深层次奥秘;</p>
要熟练掌握服务器和客户端的通信机制;</p>
要通晓基本的网络安全知识……</p>
而在密码学方面,你要掌握对称加密和非对称加密的基本原理和应用。</p>
要能理解常见的加密算法(如aes、rsa等)。</p>
准备跟比特币打交道你还得熟悉哈希算法及其在数据完整性中的应用。</p>
其次要了解数字签名和证书体系的工作机制。</p>
还要试着具备破解和绕过加密系统的能力。</p>
此外呢,还得掌握python、javascript等常用编程语言。</p>
要熟悉bash、powershell等脚本语言,自动化任务。</p>
要能编写各种网络扫描、嗅探和注入脚本。</p>
要理解漏洞并能编写漏洞利用程序。</p>
要熟悉多线程、并发编程,这样才能提高攻击效率。</p>
此外漏洞分析和逆向工程能力也要强。</p>
毕竟不是所有的漏洞都是现成的。</p>
要有能使用调试器和分析工具排查程序漏洞的能力。</p>
此外要熟悉常见的缓冲区溢出、sql注入等手段……</p>
光是看到这一堆“要如何如何”林枫就觉得很麻烦。</p>
相比于数学这些东西绝对算不上难。</p>
但有些东西确实不难,但不等于不折磨人。</p>
因为繁琐。</p>
想象一道分类讨论题,要分一百种情况,每个情况再要细分1000个要点,每个要点还要再分几个分支,每个分支还要……</p>
那种感觉怎么说呢无限套娃。</p>
当你要在知识的汪洋大海里游泳,得知这个知识海还有好几个“深渊”,每个“深渊”里都充满了看不见底的细节,而这些细节你又必须得全须全尾地了解。</p>
当你得知这一切的时候,那时你的心情一定以及肯定将是无比的绝望。</p>
而学习这些知识的过程就是一个拆解一个个深渊的过程。</p>
这些知识太杂、太细、太碎。</p>
越是接触这一行,林枫就越是感觉这个方向的知识浩如烟海。</p>
但偏偏每一步都不能够忽略。</p>
要走上这条道路,当然要搞懂计算机和网络的基础知识。</p>
这里“基础”可不是“简单”的意思,而是指很多平时甚至都让人忽视的内容。</p>
这类基础是所有进阶知识的根基。</p>
操作系统就是计算机的“大脑”,而网络是它的“手脚”。</p>
了解它们,你才能知道每个“细胞”是如何“通话”的。</p>
得深入理解操作系统的工作原理,比如进程管理、内存分配、文件系统……</p>
这些听上去就不好应付,但这些是基础中的基础。</p>
因为每当你想要“突破”一个系统、进入这台设备的大脑中枢,起码得先知道这个“大脑”在运行中做了哪些“自我保护”。</p>
知道了它的保护,你才能在它的“守卫”盲区里找到可趁之机。</p>
网络知识同样重要,要成为一名优秀的网络安全专家,你得熟悉tcp/ip协议。</p>
这个协议堪称网络世界的“语言”,大部分网络通信都依赖它。</p>
想象一下,如果你进入一个国家,发现每个人都在用同一种语言交谈,假如你也会这种语言,那么沟通、获取信息岂不更容易?</p>
tcp/ip协议就是这样的“共同语言”,你熟悉了这套共同语言,就可以在网络世界自由“行走”,掌握别人的通信方式。</p>