博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
IP数据报首部校验和算法
阅读量:6325 次
发布时间:2019-06-22

本文共 2465 字,大约阅读时间需要 8 分钟。

当用google搜索IP数据报首部校验和算法的时候,总是看到的是代码,没有看到其过程,于是就有了此文,如有错误请指正。文章省略一点,呵呵
 
IP/ICMP/IGMP/TCP/UDP等协议的校验和算法都是相同的,算法如下:
在发送数据时,为了计算数IP据报的校验和。应该按如下步骤:
(1)把IP数据报的首部都置为0,包括校验和字段。
(2)把首部看成以16位为单位的数字组成,依次进行二进制反码求和。
(3)把得到的结果存入校验和字段中。
在接收数据时,计算数据报的校验和相对简单,按如下步骤:
 
(1)当接收IP包时,需要对报头进行确认,检查IP头是否有误,算法同上2、3步,然后判断取反的结果是否为0,是则正确,否则有错。

  

1、发送方
  i)将校验和字段置为0,然后将IP包头按16比特分成多个单元,如包头长度不是16比特的倍数,则用0比特填充到16比特的倍数;
 
  ii)对各个单元采用反码加法运算(即高位溢出位会加到低位,通常的补码运算是直接丢掉溢出的高位),将得到的和的反码填入校验和字段;
 
  iii)发送数据包。
 
2、接收方
  i)将IP包头按16比特分成多个单元,如包头长度不是16比特的倍数,则用0比特填充到16比特的倍数;
 
  ii)对各个单元采用反码加法运算,检查得到的和是否符合是全1(有的实现可能对得到的和会取反码,然后判断最终值是不是全0);
 
iii) 如果是全1则进行下步处理,否则意味着包已变化从而丢弃之。需要强调的是反码和是采用高位溢出加到低位的,如3比特的反码和运 算:100b+101b=010b(因为100b+101b=1001b,高位溢出1,其应该加到低位,即001b+1b(高位溢出位)=010b)。

 1.实例

请看我用ominipeek的抓包

I.将校验和字段置为0,然后将IP包头按16比特分成多个

 

校验和Header Checksum:0x618D将其重置为0X0000

将IP包头分段:

        1.  0x4500

        2.  0x0029

        3.  0x44F1

        4.  0x4000

        5.  0x8006

        6.  0x0000 ------->这个为Header Checksum的值,我们前面将其重置为0了

        7.  0xC0A8

        8.  0x01AE

        9.  0x4A7D

+       10.  0x477D

-------------------------------------------------------

将1至10相加求出来的和为:0x29E70

II.对各个单元采用反码加法运算(即高位溢出位会加到低位,通常的补码运算是直接丢掉溢出的高位),将得到的和的反码填入校验和字段

0x0002+0x9E70=0x9E72

0x9E72二进制为:1001 1110 0111 0010

反码为:0110 0001 1000 1101

0110 0001 1000 1101的16进制为:0x618D

看看这个 是否与IP包头中的Checksum相同

==========================================================

当接收到IP对其进行检测

III.对各个单元采用反码加法运算,检查得到的和是否符合是全1(有的实现可能对得到的和会取反码,然后判断最终值是不是全0)

当收到IP数据局包的时候,要验证IP头是否正确,则可以这样进行

        1.  0x4500

        2.  0x0029

        3.  0x44F1

        4.  0x4000

        5.  0x8006

        6.  0x618D ------->这个为Header Checksum的值

        7.  0xC0A8

        8.  0x01AE

        9.  0x4A7D

+       10.  0x477D

-------------------------------------------------------

将1至10相加求出来的和为:0x2FFD

对各个单元采用反码加法运算(即高位溢出位会加到低位,通常的补码运算是直接丢掉溢出的高位),将得到的和的反码填入校验和字段

0x0002+0x0FFD=0xFFFF

0xFFFF二进制为:1111 1111 1111 1111

1111 1111 1111 1111反码为:0

====================================================

关于这一部的补充说明,

将IP包头分段:
 
        1.  0x4500
 
        2.  0x0029
 
        3.  0x44F1
 
        4.  0x4000
 
        5.  0x8006
 
        6.  0x0000 ------->这个为Header Checksum的值,我们前面将其重置为0了
 
        7.  0xC0A8
 
        8.  0x01AE
 
        9.  0x4A7D
 
+       10.  0x477D
----------------------------------------------------------------------------------------------------------

 
 
 

    

 有些地方需要完善,请参考来源。

本文转自夏雪冬日博客园博客,原文链接:http://www.cnblogs.com/heyonggang/archive/2013/01/14/2859319.html,如需转载请自行联系原作者

你可能感兴趣的文章
警惕精神抑郁 沟通应用中华通网络电话
查看>>
为什么很多优秀的软件公司和开发者愿意开源和共享?
查看>>
印度微信Hike Messenger推出Snapchat Stories类似功能
查看>>
高通:骁龙821阳谋
查看>>
健康一体机创造更好的医疗便捷体验!
查看>>
应用程序负载平衡新风潮
查看>>
LoadRunner中Lr_save_string()函数和Itoa()函数的使用
查看>>
大数据时代来临,微软面向高校学生免费开放R Server
查看>>
简单通俗易懂:一个小例子完美解释Naive Bayes(朴素贝叶斯)分类器
查看>>
【转】使用Nginx+Lua(OpenResty)开发高性能Web应用
查看>>
陕西省以大数据助力产业结构优化转型升级
查看>>
是什么产品让VMware甘当“小白鼠”?
查看>>
iOS史上最大漏洞出现 运营商罕见发公告提醒升级
查看>>
数据库中的事物处理
查看>>
浅谈运维平台选型,提速DevOps运维
查看>>
融资租赁助力光伏产业 风险防控成关键
查看>>
苹果iPhone版间谍软件生产商无底线:给钱就植入
查看>>
gatling官方文档翻译2
查看>>
利用maven与testng来进行测试Maven2 基础教程(3) - pom.xml 文件简介
查看>>
JAVA学习:成员内部类基本概念及用法
查看>>