python - 在C++中创建数据包嗅探器

标签 python c++ sockets communication

我之前使用python创建了一个简单的数据包嗅探器,其代码如下:

import socket
import os
import time

host = "192.168.0.164"

if os.name == "nt":
    socket_protocol = socket.IPPROTO_IP
else:
    socket_protocol = socket.IPPROTO_ICMP

while True:
    sniffer = socket.socket(socket.AF_INET, socket.SOCK_RAW, socket_protocol)

    sniffer.bind((host, 0))

    sniffer.setsockopt(socket.IPPROTO_IP, socket.IP_HDRINCL, 1)

    sniffer.ioctl(socket.SIO_RCVALL, socket.RCVALL_ON)

    out = sniffer.recvfrom(65565)

    print("recieved {0} bytes from: {1}:{2}".format(len(out[0]), out[1][0], out[1][1]))

    sniffer.ioctl(socket.SIO_RCVALL, socket.RCVALL_OFF)
在一个循环中,它打印出接收到的数据包数据的大小(以字节为单位)以及发送方和端口的ip地址。
我正在尝试使用c++重新创建该程序,这就是我到目前为止所要做的:
#include <winsock2.h>
#include <Ws2tcpip.h>
#include <Mstcpip.h>
#include <iostream>
#include <windows.h>

#define PORT 0

struct sockaddr_in address;

SOCKET sock;

const char opt = 0;

u_long mode_on = RCVALL_ON;

u_long mode_off = RCVALL_OFF;

char buffer;

int main()
{

    address.sin_family = AF_INET;
    address.sin_addr.s_addr = INADDR_ANY;
    address.sin_port = htons(PORT);

    sock = socket(AF_INET, SOCK_RAW, IPPROTO_IP);

    setsockopt(sock, IPPROTO_IP, IP_HDRINCL, &opt, sizeof(opt));

    bind(sock, (struct sockaddr*) & address, sizeof(address));
    ioctlsocket(sock, SIO_RCVALL, &mode_on);

    recv(sock, &buffer, 65565, 0);

    std::cout << buffer << std::endl;

    ioctlsocket(sock, SIO_RCVALL, &mode_off);

    return 0;
}
我对C++中的套接字编程不是很熟悉。
当我运行程序时,没有输出输出。
我试过以循环方式运行该程序,以查看是否恰好在那时没有任何传入数据包,但仍然没有运气。
当我运行该程序时没有错误发生。

最佳答案

我建议您回顾一些配置和从套接字读取的完整示例。所提供的示例here似乎不仅完整,而且该页面还指定了receive函数的预期返回值。
此外,您没有正确初始化缓冲区。您实际上是在分配8位数据,然后告诉接收函数它要填充65565字节(您的意思是2 ^ 16会给您65536(或65535考虑基于缓冲区零的索引)吗?)。
最后一件事:您在python中提供的代码似乎打算在多个平台上运行,但是C++代码仅适用于Windows。我建议在尝试将其转移到任何其他平台之前,先集中精力使其在单个平台上运行。

关于python - 在C++中创建数据包嗅探器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63550685/

相关文章:

python - pandas.DataFrame.plot(kind ="bar")的更多绘图选项

python :Read from a USB HID device

.net - 确定何时在(非托管)C++ 中加载 .NET

c - C中的UDP套接字不起作用

python - 如何向 Airflow 添加新的 DAG?

python - 如何正确使用 fillna() 作为 pandas 数据框中的日期时间列(不起作用)?

c++ - boost::bind 打破了严格的别名规则?

c++ - 在结构中,使用一个数组字段访问另一个数组字段是否合法?

php - 如何使用socket和mysql发送多个值存储在数据库中

java - RMI 运行时何时断开客户端连接?