linux之网络编程ICMP校验算法
生活随笔
收集整理的這篇文章主要介紹了
linux之网络编程ICMP校验算法
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
1、ICMP校驗(yàn)算法代碼
?
unsigned short cal_chksum(unsigned short *addr,int len) { int nleft = len; int sum = 0; unsigned short *w = addr; unsigned short answer =0; /*把ICMP報(bào)頭二進(jìn)制數(shù)據(jù)以2字節(jié)為單位累加起來*/ while(nleft > 1) { sum += *w++; nleft -= 2; } /*若ICMP報(bào)頭為奇數(shù)個(gè)字節(jié),會(huì)剩下最后一字節(jié)。把最后一個(gè)字節(jié)視為一個(gè)2字節(jié)數(shù)據(jù)的高字節(jié),這個(gè)2字節(jié)數(shù)據(jù)的低字節(jié)為0,繼續(xù)累加*/ if(nleft == 1) { *(unsigned char *)(&answer)=*(unsigned char *)w; sum+=answer; } /*校驗(yàn)和是以16位為單位進(jìn)行求和計(jì)算的,sum是32位的,sum&0xffff是低16位,sum>>16是右移16位,取到的是高16位,相加就是高16位和低16位的和。*/ sum = (sum >> 16) + (sum & 0xffff); /*這一步是有可能上面加的時(shí)候有進(jìn)位到高16位的,再把高16位加進(jìn)來。*/ sum += (sum >> 16); /*上一步肯定不會(huì)再有進(jìn)位了,即使上面sum高16位非0也不要緊,此處sum只能把低字節(jié)數(shù)賦值給answer,因?yàn)閍nswer為16位*/ answer =~ sum; return answer; }?
?
?
?
?
總結(jié)
以上是生活随笔為你收集整理的linux之网络编程ICMP校验算法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux c之<setjmp.h>使用
- 下一篇: ios之第一个程序Hello word,