Libpcap库编程指南--网卡数据包捕获

这篇博客介绍了如何使用Libpcap库中的pcap_next()函数替代pcap_loop()来捕获网卡数据包。相比基于回调的pcap_loop(),pcap_next()更直接,简化了在多线程C++程序中的处理。示例代码展示了在UNIX/Linux环境下如何应用pcap_next()进行数据包捕获。
摘要由CSDN通过智能技术生成

本讲的范例程序所实现的功能和效果和上一讲的非常相似 (打开适配器并捕获数据包), 但本讲将用 pcap_next() 函数代替上一讲的 pcap_loop()函数。
pcap_loop()函数是基于回调的原理来进行数据捕获,这是一种精妙的方法,并且在某些场合中,它是一种很好的选择。 然而,处理回调有时候并不实用 – 它会增加程序的复杂度,特别是在拥有多线程的C++程序中。

可以通过直接调用pcap_next() 函数来获得一个数据包 – 只有当编程人员使用了 pcap_next() 函数才能收到数据包。

这个函数的参数和捕获回调函数的参数是一样的 – 它包含一个网络适配器的描述符和两个可以初始化和返回给用户的指针 (一个指向 pcap_pkthdr 结构体,另一个指向数据报数据的缓冲)。

在下面的程序中,我们会再次用到上一讲中的有关回调方面的代码,只是我们将它放入了main()函数,之后调用 pcap_next()函数。
示例代码(根据WinPcap文档修改,适用于UNIX/Linux):

#include "pcap.h"
#include <ctime>
#include <cstdlib>

int main()
{
    pcap_if_t *alldevs;
    pcap_if_t *d;
    int inum;
    int i=0;
    pcap_t *adhandle;
    int res;
    char errbuf[PCAP_ERRBUF_SIZE];
    struct tm *ltime;
    char
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值