windows抓包简单的实现

转载请注明出处:http://blog.csdn.net/drecik__/article/details/8071902

 

因为要自己分析包内容,所以首先得自己定义IP头结构体和其他协议头(当然不能随便定义,要按照它要求的格式)

定义IP头:

// 20字节的IP头;
typedef struct _IP_HEADER 
{
	UCHAR	iphVerLen;		// 版本号和长度(各四位);
	UCHAR	iphTOS;			// 服务类型;
	USHORT	iphLength;		// 封包总长度;
	USHORT	iphID;			// 封包标识;
	USHORT	iphFlags;		// 标志;
	UCHAR	iphTTL;			// 生存时间;
	UCHAR	iphProtocol;	// 协议类型;
	USHORT	iphCheckSum;	// 校验和;
	ULONG	iphSource;		// 源IP地址;
	ULONG	iphDest;		// 目标IP地址;
} IP_HEADER, *PIP_HEADER;
定义协议头,这里只有TCP头和UCP头:

// 8个字节的UDP头;
typedef struct _UCP_HEADER 
{
	USHORT	udphSourcePort;	// 源端口号;
	USHORT	udphDestPort;	// 目标端口号;
	USHORT	udphLength;		// 封包长度;
	USHORT	udphCheckSum;	// 校验和;
} UDP_HEADER, *PUDP_HEADER;

// 20个字节的TCP头;
typedef struct _TCP_HEADER 
{
	USHORT	tcphSourctPort;	// 源端口号;
	USHORT	tcphDestPort;	// 目标端口号;
	ULONG	tcphSeqNumber;	// 序列号;
	ULONG	tcphAckNumber;	// 确认号;
	UCHAR	tcphDataOffset;	// 4位首部长度/6位保留字;
	UCHAR	tcphFlags;		// 6位标志;
	USHORT	tcphWindow;		// 窗口大小;
	USHORT	tcphCheckSum;	// 校验和;
	USHORT	tcphUrgentPt;	// 紧急数据偏移量;
} TCP_HEADER, *PTCP_HEADER;


因为要分析抓到的包的ip头和其他协议头,所以不能用一般应用层的套接字,只能用原始套接字:

创建原始套接字,绑定到本地IP(这个一定要),并设置接收所有包

	// 创建原始套接字;
	SOCKET s = socket( AF_INET, SOCK_RAW, IPPROTO_IP );

	// 获得用户名;
	char szHostName[32];
	gethostname(szHostName, sizeof(szHostName));

	// 获得本地IP地址;
	hostent* pHost;
	pHost = gethostbyname(szHostName);

	SOCKADDR_IN sin;
	sin.sin_family = AF_INET;
	sin.sin_port = 0;
	memcpy( &sin.sin_addr.S_un.S_addr, pHost->h_addr_list[0], pHost->h_length );
	printf( "绑定到IP:%s", inet_ntoa(sin.sin_addr) );
	bind( s, (LPSOCKADDR)&sin, sizeof(sin) );

	// 设置接受所有包;
	DWORD dwValue = 1;
	ioctlsocket( s, SIO_RCVALL, &dwValue );

然后接收数据

	char buf[1024*10];
	int iRet;
	while ( TRUE )
	{
		iRet = recv(s, buf, 1024*10, 0);
		if ( iRet > 0 )
		{
			// 解析IP包;
			DecodeIPPacket(buf);
			// Sleep(3000);
		}
	}


解析封包的时候就是利用所定义的IP头和各种协议头来分析

具体可以下载代码来查看 网址: http://download.csdn.net/detail/drecik__/4647617


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值