网络嗅探器的编程仿真.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第 PAGE 1 页 共 NUMPAGES 1 页 集美大学计算机工程学院实验报告 课程名称:TCP/IP协议与通信程序设计 班级: 实验成绩: 实验项目名称:网络嗅探器的编程仿真 学号: 上机实践日期:20 实验项目编号:12 组号:1 上机实践时间: 2学时 实验目的 了解利用原始套接字进行通信程序的编写,编译和执行。 二、 实验内容与设计思想 利用原始套接字编程将网卡设置为混杂模式,对网络上传输的数据包进行捕获与分析,要求析出并显示数据包的发送端IP地址以及接收端的IP地址。 三、 实验使用环境 操作系统: Microsoft Windows XP SP2 编程环境: Visual C++ 6.0 四、实验步骤和调试过程 源代码: #include initsock.h #include protoinfo.h #include stdio.h #include mstcpip.h #pragma comment(lib, Advapi32.lib) CInitSock theSock; //解析tcp数据 void DecodeTCPPacket(char *pData) { TCPHeader *pTCPHdr = (TCPHeader *)pData; printf( Port: %d - %d \n, ntohs(pTCPHdr-sourcePort), ntohs(pTCPHdr-destinationPort)); // 下面还可以根据目的端口号进一步解析应用层协议 switch(::ntohs(pTCPHdr-destinationPort)) { case 21: break; case 80: case 8080: break; } } //解析ip数据 void DecodeIPPacket(char *pData) { IPHeader *pIPHdr = (IPHeader*)pData; in_addr source, dest; char szSourceIp[32], szDestIp[32]; printf(\n\n\n); // 从IP头中取出源IP地址和目的IP地址 source.S_un.S_addr = pIPHdr-ipSource; dest.S_un.S_addr = pIPHdr-ipDestination; strcpy(szSourceIp, ::inet_ntoa(source)); strcpy(szDestIp, ::inet_ntoa(dest)); printf( %s - %s \n, szSourceIp, szDestIp); // IP头长度 int nHeaderLen = (pIPHdr-iphVerLen 0xf) * sizeof(ULONG); switch(pIPHdr-ipProtocol) { case IPPROTO_TCP: // TCP协议 DecodeTCPPacket(pData + nHeaderLen); break; case IPPROTO_UDP: break; case IPPROTO_ICMP: break; } } void main() { // 创建原始套节字 SOCKET sRaw = socket(AF_INET, SOCK_RAW, IPPROTO_IP); // 获取本地IP地址 char szHostName[56]; SOCKADDR_IN addr_in; struct hostent *pHost; gethostname(szHostName, 56); if((pHost = gethostbyname((char*)szHostName)) == NULL) return ; // 在调用ioctl之前,套节字必须绑定 addr_in.sin_family = AF_INET; addr_in.sin_port = htons(0); //将本地ip复制到addr_in结构体 memcpy(addr_in.sin_addr.S_un.S_addr, pHost-h_addr_list[0], pHost-h_length); //ip转换为字符串输出 printf( Binding to interface : %s \n, ::inet_ntoa(addr_in.sin_addr)); if(bind(sRaw, (PSOCKADDR)addr_in, sizeof(addr_in)) == SOCKET_ERROR){} //ret

文档评论(0)

yurixiang1314 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档