ImageVerifierCode 换一换
格式:DOCX , 页数:11 ,大小:135.16KB ,
资源ID:25365621      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/25365621.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(解析IP数据包课程设计.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

解析IP数据包课程设计.docx

1、解析IP数据包课程设计课程设计分析为了获取网络中的IP数据包,必须对网卡进行编程,在这里我们使用套接字(socket)进行编程。但是,在通常情况下,网络通信的套接字程序只能响应与自己硬件地址相匹配的数据包或是以广播形式出发的数据包。对于其他形式的数据包,如已到达网络接口但却不是发送到此地址的数据包,网络接口在验证投递地址并非自身地址之后将不引起响应,也就是说应用程序无法收取与自己无关的数据包。我们要想获取流经网络设备的所有数据包,就需要将网卡设置为混杂模式。本程序主要由三部分构成:初始化原始套接字,反复监听捕获数据包和解析数据包。下面就结合核心代码对程序的具体实现进行讲解,同时使程序流程更加清

2、晰,去掉了错误检查等保护性代码。1. 使用原始套接字套接字分为三种,即流套接字(Stream Socket)、数据报套接字(Datagram Socket)和原始套接字(Raw Socket)。要进行IP数据包的接受与发送,应使用原始套接字。创建原始套接字的代码如下:SOCKET sock;Sock=WSASoccet(AF_INET,SOCK_RAW,IPPROTO_IP,NULL,0,WSA_FLAG_OVERRLAPPED);在WSASoccet函数中,第一个参数指定通信发生的区字段,AF_INET是针对Internet的,允许在远程主机之间通信。第二个参数是套接字的类型,AF_INET

3、地址族下,有SOCK_STREAM、SOCK_DGRAM、SOCK_RAW三种套接字类型。在这里,我们设置为SOCK_RAW,表示我们声明的是一个原始套接字类型。第三个参数依赖于第二个参数,用于指定套接字所用的特定协议,这里使用IP协议。第四个参数为WSAPROTOCOL_INFO位,该位可以置空,永远置0。第六个参数是标志位,WSA_FLAG_OVERRLAPPED表明可以使用发送接收超时设置,本课程设计也可以把这个标志位设置为NULL,因为本设计不用考虑超时情况。创建原始套接字后,IP头就会包含在接收的数据中。然后,我们可以设置IP头操作选项,调用sotscockpot函数。其中flag设

4、置为TRUE,并设定IP_HDRINCL选项,表明用户可以亲自对IP头进行处理。BOOL flag=true;setsockopt (sock,IPPROTO_IP,IP_HDRINCL,(char*)&flag,sizeof(flag);之后,使用如下代码完成对socket的初始化工作/*获取主机名*/char hostname128;gethostname(hostname, 100);/*获取IP地址*/hostent *pHostIP;pHostIP=gethostbyname(hostname);/* 填充SOCKADDR_IN的结构内容*/sockaddr_in addr_in;a

5、ddr_in.sin_addr= *(in_addr*)pHostIP-h_addr_list0;addr_in.sin_family=AF_TNET;addr-in.sin_port=htons(6000);/* 绑定socket */bind(sock, (POSCKADDR)&addr_in,sizeof(addr_in);填写sockaddr_in的内容时,其地址值应填写为本机IP地址可以通过gethostbyname()函数获取;端口号可以随便填写,但不能与系统冲突;协议族应填写为AF_INET。注意,sockaddr_in 结构的值必须是以网络字节顺序表示的值,而不能直接使用本机字

6、节顺序的值,使用htoms()函数可以将无符号短整型的主机数据转换为网络字节的顺序的数据。最后使用bind()函数将socket绑定到本地网卡上。绑定网卡后,需要WSAIoctl()函数把网卡设置为混杂模式,使网卡能够接收所有网络数据,其关键代码如下:#define SIO_RCVALL_WSAIOW(IOC_VENDOR,1)DWORD dwBufferLen10;DWORD dwBufferInLen=1;DWORD dwBytesReturned=0;WSAIoctl(SnifferSocket,IO-RCVALL,&dwBufferInLen,sizeof(dwBufferInLen)

7、,&dwBufferLen,Sizeof(dwBufferLen),&dwByteReturned,NULL,NULL);如果接收的数据包中的协议类型和定义的原始套接字匹配,那么接收到的数据就拷贝到套接字中。因此,网卡就可以接收所有经过的IP包。2.接收数据包在程序中可使用recv()函数接收经过的IP包。该函数有四个参数,第一个参数接收操作所用的套接字描述符;第二个参数接收到缓冲区的地址;第二个参数接收缓冲区的地址;第三个参数接收缓冲区的大小,也就是所要接收的字节数;第四个参数是一个附加标志,如果对所发送的数据没特殊要求,直接设为0。因为IP数据包的最大长度是65536B,因此缓冲区的大小不

8、能小于65535B。设置缓冲区后,可利用循环来反复监听接收IP包,用recv()函数接收功能的代码如下:#dedine BUFFER_SIZE 65535Char bufferBUFFER_SIZE; /设置缓冲区While(true)recv(sock,buffer,BUFFER_SIZE,0); /j接收数据包.3.定义IP头部的数据结构程序需要定义一个数据结构表示IP头部。这个数据结构应该和图7-1吻合,其代码如下:typedef struct _IP_HEADER /定义IP头unionBYTE Version; /版本前4位BYTE HdrLen; /报头标长(后四位),IP头长度;

9、BYTE ServiceType;/服务类型WORD TotalLen; /总长度WORD ID; /标识union WORD Flags; /标志Word FragOff; /分段偏移;BYTE TimeToLive; /生命期BYTE Protiocol; /协议WORD HdrChksum; /头校验和DWORD SrcAddr; /源地址DWORD DstAddr: /目的地址BYTE Options; /选项IP_HEADER;这是我们只考虑IP头部结构,不考虑数据部分。在捕获IP数据包后,可以通过指针把缓冲区的内容强制转化为IP_HEADER数据结构。IP_HEADER ip =

10、*( IP_HEADER *)buffer;4.IP包的解析解析IP包的字段有两种策略。针对长度为8位、16位和32位的字段 (或子字段)时,可以利用IP_HEADER的成员指教获取。要解析长度不是9位倍数的字段(或子字段)时,可以利用C语言中的位移以及与、或操作完成。下面给出了通过IP_HEADER解析IP头各个字段的代码。/*获取版本字段*/ip.Version4;/*获取头部长度字段*/ip.HdrLen & 0x0f;/*获取服务类型字段中的优先级子域*/ip.ServiceType5;/*获取服务类型字段中的TOS子域*/(IP.sERVICEtYPE1)&0X0F;/*获取总长度字

11、段*/ip.TotalLEN;/*获取标识字段*/ip.ID;/*解析标识字段*/DF=(ip.Flags14) &0x01;MF=(ip.Flags13) &0X01;/*获取分段偏移字段*/ip.FragOff &0x1fff;/*获取生存时间字段*/ip.TimeToLive;/*获取协议字段*/ip.Protocol;/*获取头校验和字段*/ip.HdrChksum;/*解析源IP地址字段*/inet_ntoa(*(in_addr*)&ip.SrcAddr;/*解析目的的IP地址字段*/inet_ntoa(*(in_addr*)&ip.DstAddr);程序运行结果程序流程图:NY八实

12、习体会通过这次实验,了解到关于计算机网络数据传送及处理过程中,软件起到了巨大的作用。熟悉了VC+在计算机网络方面的应用,是一次难得的机会。同学们的默锲配合和合作精神是实验成功的必要条件,而谨慎对待事物的态度是成功的关键。九. 参考文献:1计算机网络 宋凯 刘念 金海月等2数据通信与网络(第四版)吴时霖 周正康 吴永辉 译3计算机网络课程设计 吴功宜 胡晓英 张仁 何云 王宁编著程序源代码#includewinsock2.h#includews2tcpip.h#include#include#include#pragmacomment(lib,ws2_32.lib)usingnamespaces

13、td;typedefstruct_IP_HEADERunionBYTEVersion;/版本BYTEHdrLen;/ip头部长度;BYTEServiceType;/服务类型WORDTotalLen;/总长度WORDID;/标识unionWORDFlags;/标志WORDFragoff;/分段偏移;BYTETimeToLive;/生命期BYTEProtocol;/协议WORDHdrChksum;/头校验和DWORDSrcAddr;/源地址DWORDDstAddr;/目的地址BYTEOptions;/选项IP_HEADER;intmain()SOCKETsock;WSADATAwsData;if(

14、WSAStartup(MAKEWORD(2,2),&wsData)!=0)printf(WSAStartupfailed!n);return-1;if(sock=socket(AF_INET,SOCK_RAW,IPPROTO_IP)=INVALID_SOCKET)printf(createsocketfailedn);return-1;BOOLflag=true;if(setsockopt(sock,IPPROTO_IP,IP_HDRINCL,(char*)&flag,sizeof(flag)=SOCKET_ERROR)printf(setsockoptfailed!n);return-1;c

15、harhostName128;if(gethostname(hostName,100)=SOCKET_ERROR)printf(gethostnamefailed!n);return-1;hostent*pHostIP;if(pHostIP=gethostbyname(hostName)=NULL)printf(gethostbynamefailedn);return-1;sockaddr_inaddr_in;addr_in.sin_addr=*(in_addr*)pHostIP-h_addr_list0;addr_in.sin_family=AF_INET;addr_in.sin_port=

16、htons(6000);if(bind(sock,(PSOCKADDR)&addr_in,sizeof(addr_in)=SOCKET_ERROR)printf(bindfailedn);return-1;#defineIO_RCVALL_WSAIOW(IOC_VENDOR,1)DWORDdwBufferLen10;DWORDdwBufferInLen=1;DWORDdwBytesReturned=0;charbuffer100;if(WSAIoctl(sock,IO_RCVALL,&dwBufferInLen,sizeof(dwBufferInLen),&dwBufferLen,sizeof

17、(dwBufferLen),&dwBytesReturned,NULL,NULL)=SOCKET_ERROR)printf(ioctlsocketfaildn);return-1;printf(开始解析经过本机的IP数据包!nn);while(true)intsize=recv(sock,buffer,sizeof(buffer),0);IP_HEADERip=*(IP_HEADER*)buffer;cout-endl;cout版本:4)endl;coutIP头部长度:(ip.HdrLen&0x0f)*4)endl;cout服务类型:Priority5),Service1)&0x0f)endl

18、;cout总长度:ip.TotalLenendl;cout标识符:ip.IDendl;cout标志位:15)&0x01),DF=14)&0x01),Mf=13)&0x01)endl;cout分段偏移:(ip.Fragoff&0x1fff)endl;cout生存周期:(int)ip.TimeToLiveendl;cout协议:Protocol(int)ip.Protocolendl;cout头校验和:ip.HdrChksumendl;cout源地址:inet_ntoa(*(in_addr*)&ip.SrcAddr)endl;cout目的IP地址:inet_ntoa(*(in_addr*)&ip.DstAddr)endl;:closesocket(sock);:WSACleanup();return0;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1