- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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)