Я пытаюсь использовать библиотеку 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 может без проблем прослушать интерфейс.
Я сомневаюсь, что название вашего интерфейса \\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);
Других решений пока нет …