typedef struct _TCP{ WORD SrcPort; // 源端口
WORD DstPort; // 目的端口
DWORD SeqNum; // 顺序号
DWORD AckNum; // 确认号
BYTE DataOff; // TCP头长
BYTE Flags; // 标志(URG、ACK等)
WORD Window; // 窗口大小
WORD Chksum; // 校验和
WORD UrgPtr; // 紧急指针
} TCP;
typedef TCP *LPTCP;
typedef TCP UNALIGNED * ULPTCP; 
typedef struct _IP{
union{ BYTE Version; // 版本
BYTE HdrLen; // IHL
};
BYTE ServiceType; // 服务类型
WORD TotalLen; // 总长
WORD ID; // 标识
union{ WORD Flags; // 标志
WORD FragOff; // 分段偏移
};
BYTE TimeToLive; // 生命期
BYTE Protocol; // 协议
WORD HdrChksum; // 头校验和
DWORD SrcAddr; // 源地址
DWORD DstAddr; // 目的地址
BYTE Options; // 选项
} IP; 
typedef struct _shuju
{
IP ip;
TCP tcp;
} SHUJU;
typedef IP * LPIP;
typedef IP UNALIGNED * ULPIP;
SOCKET sck;
#pragma comment(lib,"ws2_32") void send()
{
WSADATA WSAData;
char LocalName[200];
HOSTENT *pHost;
BOOL flag=TRUE;
SOCKADDR_IN addr_in;
TCP tcp;
IP ip;
char RecvBuf[512];
WSAStartup(MAKEWORD(2, 2), &WSAData);
sck = socket(AF_INET, SOCK_RAW, IPPROTO_RAW);
gethostname((char*)LocalName, sizeof(LocalName)-1);
pHost = gethostbyname((char*)LocalName);
addr_in.sin_addr.S_un.S_addr =inet_addr("192.168.0.100"); //IP
addr_in.sin_family = AF_INET;
addr_in.sin_port = htons(90);
setsockopt(sck, IPPROTO_IP, IP_HDRINCL, (char*)&flag, sizeof(flag));
char buffer[40];
memset(buffer,0,40);
SHUJU* kkk=(struct _shuju*)buffer;
kkk->ip.DstAddr=inet_addr("192.168.0.169");
kkk->ip.SrcAddr=inet_addr("192.168.0.163");
kkk->tcp.DstPort=htons(90);
kkk->tcp.SrcPort=htons(198);
int k=sendto(sck,buffer,sizeof(struct _shuju),0,(struct sockaddr*)&addr_in,sizeof(struct sockaddr_in));
}// 唯一的应用程序对象CWinApp theApp;using namespace std;int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{
int nRetCode = 0; // 初始化 MFC 并在失败时显示错误
if (!AfxWinInit(::GetModuleHandle(NULL), NULL, ::GetCommandLine(), 0))
{
// TODO: 更改错误代码以符合您的需要
_tprintf(_T("致命错误:MFC 初始化失败\n"));
nRetCode = 1;
}
else
{
// TODO: 在此处为应用程序的行为编写代码。
send();
} return nRetCode;
}测试环境是局域网,本机地址是192.168.0.160
本意是发送一个错误格式的数据包,程序运行后,并没有发现发送失败,但用自己做的一个sniffer程序却收不到数据包(两个程序运行在同一台机器上)。
是什么原因呢?

解决方案 »

  1.   

    我的sniffer程序是监测所有网卡数据
      

  2.   

    1.先不要截保证可以收发数据
    2.发送一个错误数据包,确认server收到
    3.用sniffer截,看看有没有
    4.发包和截包在一个机子上是可以的,我现在就这样做的。还有仔细看看你截的包,是不是你看走眼了。因为如果你截所有的包那么你会截到很多很多包的,是不是不仔细漏了阿。
      

  3.   

    没有42只有10042
    解释是:
    Bad protocol option. 
    An unknown, invalid or unsupported option or level was specified in a getsockopt or setsockopt call.
      

  4.   

    sendto的返回值是发送的字节数,42