一个嗅探 window 系统TCP/IP 数据包的 Raw Socket class

  网络嗅探器 sniffer 很多,不过自己做的有很多好处。window2000, XP 支持 raw socket,可以用 raw socket 构造一些特殊用途的工具.

 
#include <windows.h>
#include "winsock2.h"
#include "IPHeader.h"
 
class CRawSocket 
{
                SOCKET                 m_InSocket;
                SOCKET                 m_OutSocket;
 
                DWORD                   m_LocalIPAddress;
                WORD                     m_LocalPort;
                DWORD                   m_RemoteIPAddress;
                WORD                     m_RemotePort;
                int                            m_SendProtocal;
 
public :
                CRawSocket();
                virtual ~CRawSocket();
 
                void FinalIPHeader(char* pIpAndDataBuffer, int length);
                void ConstructIPHeader(IPHEADER* pIpHeader, int dataLength);
                void FinalTCPHeader(char* pTcpAndDataBuffer, int length);
                void ConstructTCPHeader(TCPHEADER* pTcpHeader);
                bool SendRawData(char* buffer, int length);
                bool Receive(char* buffer, int bufferSize, int& receivedLength);
                bool CreateSendSocket(LPCTSTR protocal);
                bool CreateReceiveSocket(int port=-1);
                DWORD GetLocalIPAddress();
                void SetLocalPort(int port);
                void SetRemote(DWORD remoteIP, int remotePort);
 
protected :
                unsigned short CalculateChecksum(char* buffer1, int len1, char* buffer2, int len2);
 
 
};
 
 
CPP 文件,在 thread 中使用 Receive 函数,可以获取网络中的数据包。 SendRawData 是发送一个自己构造数据包,仅仅是发送,不管 ack 应答,也不管 remote IP and port 。其余几个函数用于构造 Raw TCP/IP data.
 
#include "stdafx.h"
#include "RawSocket.h"
#include <ws2tcpip.h>
#include "IPHeader.h"
 
#define SIO_RCVALL            _WSAIOW(IOC_VENDOR,1)
#define RCVALL_OFF             0
#define RCVALL_ON              1
#define RCVALL_SOCKETLEVELONLY 2
 
 
CRawSocket::CRawSocket()
{
                WSADATA             wsaData;
                char szHostName[128];
                m_InSocket = INVALID_SOCKET;
                m_OutSocket = INVALID_SOCKET;
 
                if (::WSAStartup(MAKEWORD(2, 2), &wsaData) != 0) {
                                CString s;
                                s.Format("Error socket()= %ld", ::GetLastError());
                                ::AfxMessageBox(s);
                }              
 
                ::gethostname(szHostName, sizeof(szHostName));
                HOSTENT* pHostEnt = ::gethostbyname(szHostName);
                if (pHostEnt != NULL)
                                m_LocalIPAddress = *((DWORD*) pHostEnt->h_addr_list[
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
本文章将介绍如何使用RawSocket(原始套接字)开发网络嗅探器: 首先我们得了解什么是套接字,这个我就不多说,自己百度,百度百科比我说的好。 那么什么又是原始套接字呢,常用的套接字分为 SOCK_STREAM(流套接字) 用于TCPXY通讯。 SOCK_DGRAM(数据报套接字) 同于UDPXY通讯。 那么原始呢,他则是和名字一样原始套接字;举例:要想用流套接字进行一次TCP的发包,那么直接连接上对方服务器然后用Send就可以发送指定的内容,但其实发送的数据并不止你的那些内容,有一些东西是流套接字会给你自动补上的。TCP是属于IPXY的一个子XY,那么要发送一个TCP数据包就得加上(以太网XY报头这个先不提),IPXY的报头,和TCPXY报头,这些东西流套接字都会帮你处理,而原始套接字则不会(当然也可以设置让原始套接字构造IP报头)。原始套接字他有更多的用途,但相对来说也比流套接字或数据报套接字麻烦。 原始套接字还可以设置成允许接收本地所有的套接字数据。那么我们就利用这个功能来做嗅探器! 首先:1.使用  WSAStartup (合并短整数 (2, 2), WSADATA)  来初始化Winsocket服务 其参数有2个  第一个 (短整数型/双字节型):wVersionRequired  这个参数表明使用的winsock版本号,高位指定修订版本号,低位指定主版本号。第二个参数 WSADATA类型 用于接收Winsocket细节东西,咱不用管它。 //下面就不说那么详细了,源码里面全是注释,自己看。 2.然后使用socket (#AF_INET, #SOCK_RAW, #IPPROTO_IP)  来创建一个套接字   第一个参数应该是表明Internet地址格式反正只能固定这个,仅仅支持这个  参数2:表明要创建的是一个原始套接字,参数3:指定IPXY  IPXY包括其子XY TCP UDP 等。成功返回套接字句柄 3.  bind (s, addr, sizeof (addr))  将套接字绑定至指定网卡,参数1=套接字句柄    参数2为一个addr结构的值,该值表明要绑定的网卡IP及端口号 4.  ioctlsocket (Socket, 2550136833, 1) 将套接字的模式改变为允许接收所有数据 顺利完成上面的操作后咱就可以用Recv来接收数据包了,只要不断的调用Recv就OK。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值