作業:首部校驗和計算

IP首部校驗和的計算主要是兩步:按位異或和取反,具體來說
1. IP頭部以16位爲一個單位,逐個模2加(相當於異或);
2. 得到的結果取反,作爲校驗和放入校驗和字段;
3. 初始計算校驗和字段時該字段全部用0填充;
     以上是對於發送者來說如何計算校驗和的,而對於接收者來說,驗證也很簡單:
1. 對於接收的IP報文頭部以16位爲單位逐個求和;
2. 若結果爲1,則校驗正確,否則出錯丟棄;
     原理很簡單,接收方的計算對象是A和A的反的異或,結果當然是1了!
     具體的程序實現例子如下:

  1. SHORT checksum(USHORT* buffer, int size)

  2. {

  3.     unsigned long cksum = 0;

  4.     while(size>1)

  5.     {

  6.         cksum += *buffer++;

  7.         size -= sizeof(USHORT);

  8.     }

  9.     if(size)

  10.     {

  11.         cksum += *(UCHAR*)buffer;

  12.     }

  13.     cksum = (cksum>>16) + (cksum&0xffff);

  14.     cksum += (cksum>>16);

  15.     return (USHORT)(~cksum);

  16. }

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,得到的結果是全一,正確。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章