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

问题描述

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

dyn FnMut() -> i32

一个循环中,它打印出接收到的数据包数据的大小(以字节为单位)以及发送方和端口的ip地址。 我正在尝试使用c ++重新创建此程序,这是我到目前为止所要做的:

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)

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

解决方法

我建议您查看一些配置和读取套接字的完整示例。 here提供的示例似乎不仅完整,而且页面还指定了接收函数的预期返回值。

此外,您没有正确初始化缓冲区。您实际上是分配8位数据,然后告诉接收函数它要填充65565字节(您的意思是2 ^ 16会给您65536(或65535表示基于缓冲区零的索引)吗?)。

最后一件事:您在python中提供的代码似乎打算在多个平台上运行,但是C ++代码仅适用于Windows。我建议在尝试将其转移到任何其他平台之前,先将其重点放在单个平台上。