winpcap的使用


1、通常,编写基于WinPcap应用程序的第一件事情,就是获得已连接的网络适配器列表。libpcap和WinPcap都提供了 pcap_findalldevs_ex() 函数来实现这个功能: 这个函数返回一个 pcap_if 结构的链表, 每个这样的结构都包含了一个适配器的详细信息。值得注意的是,数据域 name 和 description 表示一个适配器名称和一个可以让人们理解的描述。下列代码能获取适配器列表,并在屏幕上显示出来,如果没有找到适配器,将打印错误信息。
有关这段代码的一些说明首先, pcap_findalldevs_ex() ,和其他libpcap函数一样,有一个 errbuf 参数。一旦发生错误,这个参数将会被libpcap写入字符串类型的错误信息。
第二要记住,不是所有的操作系统都支持libpcap提供的网络程序接口,因此,如果我们想编写一个可移植的应用程序,我们就必须考虑在什么情况下, description 是 null。本程序中,我们遇到这种情况时,会打印提示语句”No description available”。最后要记住,当我们完成了设备列表的使用,我们要调用 pcap_freealldevs() 函数将其占用的内存资源释放。让我们编译并运行我们的第一个示例程序吧! 为了能在Unix或Cygwin平台上编译这段程序,需要简单输入:gcc -o testprog testprog.c -lpcap

2、具体实现代码:// 1406404002.cpp : 定义控制台应用程序的入口点。#include “stdafx.h”#include “pcap.h”
int _tmain(int argc, _TCHAR* argv[]){ pcap_if_t *alldevs; pcap_if_t *d; int i=0; char errbuf[PCAP_ERRBUF_SIZE]; /* 获取本地机器设备列表 */ if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL /* auth is not needed */, &alldevs, errbuf) == -1) { fprintf(stderr,”Error in pcap_findalldevs_ex: %sn”, errbuf); exit(1); } /* 打印列表 */ for(d= alldevs; d != NULL; d= d->next) { printf(“%d. %s”, ++i, d->name); if (d->description) printf(” (%s)n”, d->description); else printf(” (No description available)n”); } if (i == 0) { printf(“nNo interfaces found! Make sure WinPcap is installed.n”); return 0; }
/* 不再需要设备列表了,释放它 */ pcap_freealldevs(alldevs);}
3、具体配置:**=(1406404002)项目–>**属性(alt+F7)配置属性–>清单工具–>输入和输出–>嵌入清单–>否项目–>**属性(alt+F7)配置属性–>C/C++–>常规–>附加包含目录–>例:C:WpdPack_4_1_2WpdPackInclude项目–>**属性(alt+F7)配置属性–>链接器–>常规–>附加库目录–>例:C:WpdPack_4_1_2WpdPackLib项目–>**属性(alt+F7)配置属性–>链接器–>输入–>附加依赖项–>补充“;Packet.lib;wpcap.lib”项目–>**属性(alt+F7)配置属性–>C/C++–>预处理器–>预处理器定义–>补充“;HAVE_REMOTE”

4、在Windows平台上,您需要创建一个工程,并按照 使用WinPcap编程里的步骤做。 然而,使用WinPcap developer’s pack ( 详情请访问WinPcap网站, http://www.winpcap.org ), 因为它提供了很多已经配置好的范例,包括本教程中的所有示例代码,以及在编译运行时需要的 包含文件(include) 和 库(libraries) jiash假设已经完成了对程序的编译,之后运行它。在某台WinXP的电脑上,我们得到的结果是: 1. DeviceNPF_{4E273621-5161-46C8-895A-48D0E52A0B83} (Realtek R免费云主机域名TL8029(AS) Ethernet Adapter) 2. DeviceNPF_{5D24AE04-C486-4A96-83FB-8B5EC6C7F430} (3Com EtherLink PCI)运行结果:

相关推荐: linux中eq指的是什么

本篇内容主要讲解“linux中eq指的是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“linux中eq指的是什么”吧! 在linux中,eq是“相等”的意思;Linux shell编程会用到判断字符串是否相等,…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 01/25 13:04
下一篇 01/25 13:04