如何手写网络协议栈

这篇具有很好参考价值的文章主要介绍了如何手写网络协议栈。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

哈喽,我是子牙,一个很卷的硬核男人。喜欢研究底层,聚焦做那些大家想学没地方学的课程:手写操作系统、手写虚拟机、手写编程语言…目前做了两门课:手写OS、手写JVM

今天想跟大家聊一个黑科技:手写网络协议栈。为什么说它是黑科技呢?因为这玩意是网络黑客从事一切网络保(破)护(坏)活动的基础应用!一般黑客手里都有一个自实现的网络协议栈!有了此绝技,就可以来无影去无踪了…

为了让大家更深刻的感受到我在说什么,我录了个视频演示,enjoy
 

【全网独家手写操作系统课】手把手带你用汇编+C语言一步一步实现操作系统,让你成为技术领域的顶尖专家!


技术生涯十几年,尝试过各种学习方式,但是我发现,手写是最有效也是最高效的学习方式。你觉得你已经懂了的东西,一写就发现人废了;你觉得理所当然的东西,一写就发现人大意了;你觉得很easy的东西,一写就发现人肤浅了…

比如网络协议栈,一问,都能讲几句:OSI七层模型、TCP/IP五层模型、数据链路层、网络层…如果从实战的角度去问,可能就有点懵了,比如:如何防止TCP包伪造、TCP包不带timestamps会出现问题吗,什么问题;网络协议栈底层是如何保证TCP包的顺序问题的,要细节;如何隐藏TCP连接;如何捕获隐藏的TCP连接…

你自己写一遍TCP建立连接三次握手、断开连接四次挥手、模拟数据发送、与Linux socket建立全双工通信通道,TCP协议于你,就没有秘密可言了!相反,你能hold住它,能熟练使用它达到你不可告人的秘密。学习操作系统同样如此,光学csapp,在Windows或Linux上做点小实验,是不可能真正学会操作系统的

如何手写网络协议栈


 文章来源地址https://www.toymoban.com/news/detail-478722.html

技术圈有一句很有名的话:不要重复发明轮子,这句话其实是针对工作的,就是说有得用就尽量用,不要自己瞎折腾去自己整一个,拖(浪)慢(费)进(时)度(间)。针对学习,这句话是不适用的。绝知此事要躬行,学习,求真理,就是要折腾,要站在设计者的角度去思考问题!


为什么黑客自实现了网络协议栈就可以来无影去无踪了呢?我来揭秘一下

如何手写网络协议栈

我们平时写的网络应用是基于Linux socket实现的,当你与服务器建立连接,Linux是可以通过命令查看到的

如何手写网络协议栈

但是你基于网卡自实现的网络协议栈,与服务器建立连接,除非你察觉到不对劲,抓tcp包,否则是看不到连接的。但是在你察觉到不对劲的时候,其实黑客把该干的事都干完了。。

所以说,攻防其实是相对的,就是说你有攻的方式,就有对应的守的手段,就看攻防双方是否在同一个维度。比如你写的游戏辅助只针对应用层,那玩内核的在内核态限制你,你就GG了!同样的,你入侵服务器基于自实现的网络协议栈,防守的一方从Linux socket的角度去找答案,自然是找不到的

这!就是提升实力的重要性!如果面试不在同一个维度、竞争不在同一个维度、攻防不在同一个维度…你毫无招架之力!


接下来详细说说如何手写网络协议栈,你可以按照我说的去做,不过坑很多很多,比如构建的数据包一个位不对,服务端就不响应,超级难排查…

如果你想节省时间、不踩坑、不差钱,欢迎跟我学习。手写OS三期新增的专题就是手写网络协议栈。我的直播课程+答疑,能让你在最短的时间内,学到最多的关于OS与网络协议栈的硬核知识。你掉坑里,可能我的一句话就让你爬出来了。

先上图,再说话

如何手写网络协议栈

说下应用场景,比如我们通过浏览器访问网页,大家都知道走的是http协议,http协议属于应用层协议,它是在TCP协议的基础上实现的,所以我们最终的问题还是落到,如何构建TCP包并发送

如何手写网络协议栈

一个完整的TCP包包含以太网首部+IP首部+TCP首部+数据,其中这里面还有个隐藏款:TCP伪头部,计算tcp checksum用的,这里是个巨坑!

看下以太网首部的构成,可以看出,里面有两个MAC地址,如何获取呢?

如何手写网络协议栈

本机网卡的MAC地址,你可以通过读网卡的datasheet了解如何操作网卡获得,比如我写的OS获取到的MAC地址,这个属于协议栈中的物理层了

如何手写网络协议栈

服务器网卡的MAC地址我要如何获得呢?通过ARP协议,这个属于网络层协议

如何手写网络协议栈

获得了这两个MAC地址,以太网首部包就可以构建出来了

构建IP首部、TCP首部没啥难度,就是坑比较多,想自己研究的小伙伴可自行踩坑爬坑,也是一种成长

看下我最终实现的效果:通过我自实现的网络协议栈与服务端建立连接,但是是看不到连接的

如何手写网络协议栈

我写的网络协议栈,除了可以与Linux socket模拟三次握手建立连接,建立全双工通道通信,还可以侵入正常的socket client与socket server建立的连接进行通信,意思就是我写的协议栈可以冒充客户端与服务端通信!有趣不?^_^


如果你也像我一样,喜欢研究计算机底层,并乐此不疲,无论多难,都不曾想过放弃,欢迎跟我学习。我是子牙老师,下期再见!

 

到了这里,关于如何手写网络协议栈的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 如何手写一个RPC?

    在学习 RPC 框架之前,我们先来手写一个RPC。 我们在学习的过程中,一定要做到知其然,还要知其所以然。 单体架构 要知道,在以前单体架构的时候,会将所有的应用功能都集中在一个服务当中。 单体架构初始开发简单,所有的功能都在一个项目中,容易理解整个应用的业

    2024年01月17日
    浏览(40)
  • 用C语言构建一个手写数字识别神经网络

    (原理和程序基本框架请参见前一篇 \\\"用C语言构建了一个简单的神经网路\\\") 1.准备训练和测试数据集 从http://yann.lecun.com/exdb/mnist/下载手写数字训练数据集, 包括图像数据train-images-idx3-ubyte.gz 和标签数据 train-labels-idx1-ubyte.gz. 分别将他们解压后放在本地文件夹中,解压后文件名

    2024年02月14日
    浏览(35)
  • 如何在unity中手写一个四叉树地形lod系统(二)

    在根据四叉树节点创建了1365个地形分块网格并保存到本地后,我们接下来要在游戏运行的过程中动态地显示所需的网格,这是最关键的一步。 如何根据摄像机位置动态地选择地形块?这其中体现了由整体到局部,从简单到复杂的原则。 0、 我们首先创建三个缓存列表。 1、

    2024年02月08日
    浏览(58)
  • 新接手一个业务系统,我是这么熟悉的

    接二连三地背锅让小猫的内心受到了前所未有的打击。这也是他职业生涯中的第一次。感兴趣的伙伴们如果想了解一下小猫怎么了,可以看一下“幂等事件”以及“缓存击穿事件”。 这天组长找小猫来到了一间会议室。 “在这么短的时间内发生了这么多的事故,我想也你心

    2024年01月21日
    浏览(39)
  • 我是如何写题解的

    在算法竞赛中,写题解是我们不可或缺的一部分。它不仅能够帮助我们整理思路、总结经验,还可以与他人分享我们的解题思路和代码实现。然而,写一篇较完备的题解往往非常繁琐,需要手动复制粘贴题目链接、题号和AC代码,这不仅费时费力,还容易分散我们的注意力,

    2024年02月09日
    浏览(75)
  • 如何自定义一个协议

    先有一个需求,有个场景,打开外卖软件,会显示商家列表,列表中有很多项,每一项都包含了一些信息,商家的名称,图片,好评率,距离你的位置,评分 这些信息都是通过网络,从服务器获取的, 客户端,需要给服务器发送一个请求,服务器收到请求之后,就给客户端返回一个响应,这里的请

    2024年02月22日
    浏览(30)
  • 我是如何利用midjourney制作表情包的

    起初是在看到大厂文章《【Midjourney教程】设计麻瓜也能10分钟上架一套表情包》以后,才想自己试试的。如果你是midjourney的老鸟了,那么参照着文章,应该也能很顺利的完成。下面我介绍下,我遇到的问题和解决方案 准备: 一个midjourney账号,作画使用(目前架设在discord平

    2024年02月09日
    浏览(69)
  • 随身WIFI如何刷面具?我是真想教会你……

    【准备素材】 1、随身WiFi助手3.0.1(其他版本也可以)、 2、随身WIFI(我用的有新讯9600、炜广双翼)(本操作无需拆机) 3、装有win的电脑(因为我没试过mac) 4、手(小心别把键盘敲坏了) 5、眼(操作前,一定要预测你输入和点击的内容能否够达到我后面说的大体结果。)

    2024年02月06日
    浏览(123)
  • 【Java项目】我是如何实现抢红包功能的?

    使用的就是redis的list集合,然后这里有一个意外情况就是: redis如果当前用户取出数据成功了,但是此时redis宕机了,然后aof同步失败,那么下一次恢复了后,就会拿到这条没有出队的数据,数据就出错了。 但是这个线程他是成功的,所以它可以成功的执行对数据库的操作。

    2024年02月09日
    浏览(39)
  • 如何定义网络协议?网络协议有哪些意义?

    本文将向大家详细介绍如何定义网络协议以及网络协议有哪些意义的基础知识,不明白的朋友可以过来学习一下 如何定义网络协议,它有哪些意义? 网络是一个相互联结的大群体,因此要想加入到这个群体中来,就不能随心所欲,任由兴之所发。就好象一个国家或一个种族

    2024年02月06日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包