снифферы пакетов — C ++ libtins & quot; указан неверный дескриптор & quot;

Я пытаюсь использовать библиотеку libtins для C ++ и продолжаю сталкиваться с основной ошибкой.

Это мой код:

#define TINS_STATIC
#define WIN32

#include <iostream>
#include <tins/tins.h>

using namespace Tins;

int main(void) {

NetworkInterface iface = NetworkInterface::default_interface();
Sniffer sniffer(iface.name());

//more code below
}

И я получаю следующую ошибку во время выполнения:

Exception thrown at 0x00007FFD80F7DC9A (ntdll.dll) in test.exe: 0xC0000008: An invalid handle was specified.

Мой сетевой интерфейс по умолчанию «Ethernet 2». Libtins может успешно обнаружить это, когда я перечислю все интерфейсы.

{07C8C0D2-A2FC-4B91-9875-A8301682EF7C} (Ethernet 2)

Я попытался вручную ввести имя интерфейса как таковое:

Sniffer sniffer("\\Device\\NPF_{07C8C0D2-A2FC-4B91-9875-A8301682EF7C}");

Но получите эту ошибку во время выполнения:

Exception thrown at 0x00007FFD7D2EA388 in test.exe: Microsoft C++ exception: Tins::pcap_error at memory location 0x000000543FCFF790.
Unhandled exception at 0x00007FFD7D2EA388 in test.exe: Microsoft C++ exception: Tins::pcap_error at memory location 0x000000543FCFF790.

Что я делаю неправильно? Это связано с моей сетевой конфигурацией? Я на машине с Windows 10 и использую готовую 64-битную библиотеку libtins. Wireshark может без проблем прослушать интерфейс.

0

Решение

Я сомневаюсь, что название вашего интерфейса \\Device\\NPF_{07C8C0D2-A2FC-4B91-9875-A8301682EF7C}, Насколько я знаю, так как ваш интерфейс Ethernet 2, чем вы должны пройти eth2 к Sniffer объект.

Следующие работы идеально подходят для меня:

SnifferConfiguration config;
config.set_promisc_mode(true);
config.set_filter("udp and (dst port 53 or src port 53)");

Sniffer sniffer("wlp9s0", config);

sniffer.sniff_loop(callback);
0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]