




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/路由跟踪器课程设计代码部分/程序原理:程序发送一个请求回显类型为8的icmp包,开始设置此包ttl为1,到达第一个路由器时,路由器会将ttl减1,此时ttl变为0,/ 路由器即会丢弃此包,并发送一个超时类型为11的icmp包,程序接收此包,解析出此包的源ip,即为第一个路由器的ip,依次类推,/ 发第二个请求回显icmp包,ttl设置为2,第二个路由器也会像上面第一个一样处理此包,即可获得第二个路由器的ip, 这样不断的/ 增加icmp包ttl值,当ttl足够大,icmp包可以到达目的地时,/ 目的地会发送一个回应应答报文或者是目的地不可达报文,此时路由跟踪即完成#include #include #include using namespace std;#pragma comment(lib, Ws2_32.lib)typedef structunsigned char hdr_len:4; unsigned char version:4; unsigned char tos; unsigned short total_len; unsigned short identifier; unsigned short frag_and_flags; unsigned char ttl; unsigned char protocol; unsigned short checksum; unsigned long sourceIP; unsigned long destIP; IP_HEADER;typedef structBYTE type; /8位类型字段BYTE code; /8位代码字段USHORT cksum; /16位校验和USHORT id; /16位标识符USHORT seq; /16位序列号 ICMP_HEADER;/报文解码结构typedef structUSHORT usSeqNo; /序列号DWORD dwRoundTripTime; /往返时间in_addr dwIPaddr; /返回报文的IP地址DECODE_RESULT;USHORT checksum(USHORT *pBuf,int iSize)unsigned long cksum=0;while(iSize1)cksum+=*pBuf+;iSize-=sizeof(USHORT);if(iSize)cksum+=*(UCHAR *)pBuf;cksum=(cksum16)+(cksum&0xffff);cksum+=(cksum16);return (USHORT)(cksum);BOOL DecodeIcmpResponse(char * pBuf,int iPacketSize,DECODE_RESULT &DecodeResult,BYTE ICMP_ECHO_REPLY,BYTE ICMP_TIMEOUT)IP_HEADER* pIpHdr = (IP_HEADER*)pBuf;int iIpHdrLen = pIpHdr-hdr_len * 4;if (iPacketSize type=ICMP_ECHO_REPLY) /ICMP回显应答报文usID=pIcmpHdr-id; /报文IDusSquNo=pIcmpHdr-seq; /报文序列号else if(pIcmpHdr-type=ICMP_TIMEOUT) /ICMP超时差错报文char * pInnerIpHdr=pBuf+iIpHdrLen+sizeof(ICMP_HEADER); /载荷中的IP头int iInnerIPHdrLen=(IP_HEADER *)pInnerIpHdr)-hdr_len*4; /载荷中的IP头长ICMP_HEADER * pInnerIcmpHdr=(ICMP_HEADER *)(pInnerIpHdr+iInnerIPHdrLen);/载荷中的ICMP头usID=pInnerIcmpHdr-id; /报文IDusSquNo=pInnerIcmpHdr-seq; /序列号elsereturn false;if(usID!=(USHORT)GetCurrentProcessId()|usSquNo!=DecodeResult.usSeqNo)return false;DecodeResult.dwIPaddr.s_addr=pIpHdr-sourceIP;DecodeResult.dwRoundTripTime=GetTickCount()-DecodeResult.dwRoundTripTime;if (pIcmpHdr-type = ICMP_ECHO_REPLY |pIcmpHdr-type = ICMP_TIMEOUT)if(DecodeResult.dwRoundTripTime)cout DecodeResult.dwRoundTripTimemsflush;elsecout 1msflush;return true;void main()WSADATA wsa;WSAStartup(MAKEWORD(2,2),&wsa);char IpAddress255;coutIpAddress;/得到IP地址u_long ulDestIP=inet_addr(IpAddress);/转换不成功时按域名解析if(ulDestIP=INADDR_NONE)hostent * pHostent=gethostbyname(IpAddress);if(pHostent)ulDestIP=(*(in_addr*)pHostent-h_addr).s_addr;elsecout输入的IP地址或域名无效!endl;WSACleanup();return;coutTracing roote to IpAddress with a maximum of 30 hops.ntype=ICMP_ECHO_REQUEST; pIcmpHeader-code=0; pIcmpHeader-id=(USHORT)GetCurrentProcessId();memset(IcmpSendBuf+sizeof(ICMP_HEADER),E,DEF_ICMP_DATA_SIZE);/ USHORT usSeqNo=0; int iTTL=1; BOOL bReachDestHost=FALSE; /循环退出标志int iMaxHot=DEF_MAX_HOP; /循环的最大次数DECODE_RESULT DecodeResult; /传递给报文解码函数的结构化参数while(!bReachDestHost&iMaxHot-)/设置IP报头的TTL字段setsockopt(sockRaw,IPPROTO_IP,IP_TTL,(char *)&iTTL,sizeof(iTTL);coutiTTLcksum=0; /校验和先置为0(ICMP_HEADER *)IcmpSendBuf)-seq=htons(usSeqNo+); /填充序列号(ICMP_HEADER *)IcmpSendBuf)-cksum=checksum(USHORT *)IcmpSendBuf,sizeof(ICMP_HEADER)+DEF_ICMP_DATA_SIZE); /计算校验和/记录序列号和当前时间DecodeResult.usSeqNo=(ICMP_HEADER*)IcmpSendBuf)-seq; /当前序号DecodeResult.dwRoundTripTime=GetTickCount(); /当前时间/发送TCP回显请求信息sendto(sockRaw,IcmpSendBuf,sizeof(IcmpSendBuf),0,(sockaddr*)&destSockAddr,sizeof(destSockAddr);/接收ICMP差错报文并进行解析处理sockaddr_in from; /对端socket地址int iFromLen=sizeof(from); /地址结构大小int iReadDataLen; /接收数据长度while(1)/接收数据iReadDataLen=recvfrom(sockRaw,IcmpRecvBuf,MAX_ICMP_PACKET_SIZE,0,(sockaddr*)&from,&iFromLen);if(iReadDataLen!=SOCKET_ERROR) /有数据到达if(DecodeIcmpResponse(IcmpRecvBuf,iReadDataLen,DecodeResult,ICMP_ECHO_REPLY,ICMP_TIMEOUT)if(DecodeResult.dwIPaddr.s_addr=des
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 百年老药阿司匹林80课件
- 2023年上海市上海市徐汇区斜土路街道招聘社区工作者真题带答案详解
- 2025年江西省高速公路投资集团有限责任公司招聘笔试备考题库附答案详解(a卷)
- 2025年黑龙江省五常市辅警招聘考试试题题库及答案详解(网校专用)
- 高温伺服阀力矩马达的工作特性及散热罩优化研究
- 2025年河北省定州市辅警招聘考试试题题库完整参考答案详解
- 债券研究-固收专题报告:全球价值链分工与关税博弈-关税成本由谁承担
- 语文(深圳卷)2025年中考考前押题最后一卷
- 临床抗生素耐药性与合理用药护理要点
- ISO9000质量管理体系
- KCA试题库完整版
- 永久性用电施工方案
- 2024年新版药品管理法培训
- 柴油发电机组降噪解决方案
- 《老年人权益保障法》课件
- 2022年高中英语学科教学计划
- DB51T 2845-2021 连续玄武岩纤维生产原料技术规范
- 2025届湖南省高考化学第一轮复习模拟选择题-化学与生活43道(附答案)
- 生物化学检验技术 课件 第七章 糖代谢紊乱检验
- 物理-2025年中考终极押题猜想(广州专用)(原卷版)
- 医院培训课件:《血液净化质量控制标准解读》
评论
0/150
提交评论