ip協議解析 首部校驗和

wKiom1f8lxHzbolaAACOMlQ6yj8242.png-wh_50

3. 初始計算校驗和字段時該字段所有用0填充;
     以上是對於發送者來講如何計算校驗和的,而對於接收者來講,驗證也很簡單:
1. 對於接收的IP報文頭部以16位爲單位逐個求和;
2. 若結果爲1,則校驗正確,不然出錯丟棄;
     原理很簡單,接收方的計算對象是A和A的反的異或,結果固然是1了!
     具體的程序實現例子以下:
SHORT checksum(USHORT* buffer, int size)
{
    unsigned long cksum = 0;
    while(size>1)
    {
        cksum += *buffer++;
        size -= sizeof(USHORT);
    }
    if(size)
    {
        cksum += *(UCHAR*)buffer;
    }
    cksum = (cksum>>16) + (cksum&0xffff);
    cksum += (cksum>>16);
    return (USHORT)(~cksum);
}
IP頭:
4500 0046
17d9 0000
4011 ec1d(校驗字段)
ac1c 0f3b
ac1c 0f3d
計算:
4500 + 0046 +17d9 + 0000 + 4011+ ec1d +ac1c + 0f3b + ac1c + 0f3d
  取出的和相加再取反->即爲應填充的校驗和
  當接受到IP數據包時,要檢查IP頭是否正確,則對IP頭進行檢驗,方法同上:
  計算:
  44500 + 0046 +17d9 + 0000 + 4011+ ec1d +ac1c + 0f3b + ac1c + 0f3d再與它們的和相加得出的一個數再次相加爲FFFF,獲得的結果是全一,正確。ide

相關文章
相關標籤/搜索