C++計算ICMP頭的校驗和實例
更新時間:2014年10月21日 11:30:29 投稿:shichen2014
這篇文章主要介紹了C++計算ICMP頭的校驗和的方法,代碼簡單實用,對于校驗ICMP報文來說有不錯的實用價值,需要的朋友可以參考下
本文實例講述了C++計算ICMP頭的校驗和的方法,分享給大家供大家參考。具體實現(xiàn)代碼如下:
復制代碼 代碼如下:
USHORT checksum(USHORT* buff, int nSize)
{
unsigned long cksum=0;
//將數(shù)據(jù)以字為單位加到cksum
while (nSize > 1)
{
cksum += *buff++;
nSize -= sizeof(USHORT);
}
//如果為奇數(shù), 將最后一個字擴展到雙字,再累加
if (nSize)
{
cksum += *(UCHAR*)buff;
}
//將cksum的高16位與低16位相加,取反后得到校驗和
cksum = (cksum>>16) + (cksum&&0xffff);
cksum += (cksum>>16);
return (USHORT)(~cksum);
}
{
unsigned long cksum=0;
//將數(shù)據(jù)以字為單位加到cksum
while (nSize > 1)
{
cksum += *buff++;
nSize -= sizeof(USHORT);
}
//如果為奇數(shù), 將最后一個字擴展到雙字,再累加
if (nSize)
{
cksum += *(UCHAR*)buff;
}
//將cksum的高16位與低16位相加,取反后得到校驗和
cksum = (cksum>>16) + (cksum&&0xffff);
cksum += (cksum>>16);
return (USHORT)(~cksum);
}
希望本文所述對大家的C++程序設(shè)計有所幫助。
相關(guān)文章
數(shù)據(jù)結(jié)構(gòu)串的操作實例詳解
這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu)串的操作實例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07