Winpcap简介及Winpcap安装包和开发包下载地址:
Winpcap是一个强大的网络开发库,可以实现许多功能:获取可用的网络适配器;获取指定适配器信息(比如名称和描述信息);捕获指定网卡的数据封包;发送数据封包;过滤捕获的包以获取特定包等。
首先到
|http://www.winpcap.org/install/default.htm
下载安装winpcap 驱动和DLL组件。
注意下图被红线圈起来的地方,即使下载地址,点击进入
然后到http://www.winpcap.org/devel.htm.下载winpcap开发包,
(#注意别踩坑千万注意不要下载4.0.2,下载之前的版本3.1!!!!->
https://www.winpcap.org/archive/)解压到指定目录,这里我解压到C:\WpdPack_4_0_2\WpdPack,可以看到里面包含了:Lib,Include,文档和示例程序。
把安装包和开发包下载下来后,执行安装包,这样你的机子就能运行winpcap程序了,解压开发包里面有
具体解决方法:
这里的include和lib文件夹里的东西因为vc6.0里没有,所以编译一些程序时我们要手动添加。如果出现fatal error C1083: Cannot open include file: ‘pcap.h’: No such file or directory这个问题,就需要添加了。
下面是具体添加步骤:
第一步:
点菜单栏上的“工具”,再点击下拉菜单中的“选项”弹出“选项”对话框
点“目录”在“目录【S】”的下面选择include files然后按底下的添加符号,把你写的winpcap
开发包解压到的具体路径添加进去,如上图我的路径是
C:WpdPack 4 1 beta4\WpdPack\include把这个添加进去就行了
然后选择“目录”下的下拉菜单中的library files
把winpcap开发包里的lib文件路径添进去,我的是C:\WpdPack_4_1_beta4\WpdPack\Lib。
第二步
菜单栏里的 工程——设置 ,弹出project settinggs对话框,点击连接
然后在“对象/库模块”下加入wpcap.lib Packet.lib Ws2_32.lib注意这个地方每个之间用空格隔开。
然后再在这个对话框里点 C\C++
在“预处理程序定义”下加上WPCAP,HAVE_REMOTE,注意它们之间用逗号隔开
Winpcap的环境就部署好了
在VC6.0里建一个工程 ,工程——win32 console aplicatio,然后再在工程里新建一个一个C\C++ Source File文件把下面代码粘贴进去
运行编译,检测环境是否真的配好了,结果应该是零错误,编译成功。
#include "pcap.h"
#include <remote-ext.h>
//#include <ntddndis.h>
#pragma comment( lib, "wpcap.lib" )
/* packet handler 函数原型 */
void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data);
main()
{
pcap_if_t *alldevs;
pcap_if_t *d;
int inum;
int i=0;
pcap_t *adhandle;
char errbuf[PCAP_ERRBUF_SIZE];
/* 获取本机设备列表 */
if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL, &alldevs, errbuf) == -1)
{
fprintf(stderr,"Error in pcap_findalldevs: %s\n", errbuf);
exit(1);
}
/* 打印列表 */
for(d=alldevs; d; 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 -1;
}
printf("Enter the interface number (1-%d):",i);
scanf("%d", &inum);
if(inum < 1 || inum > i)
{
printf("\nInterface number out of range.\n");
/* 释放设备列表 */
pcap_freealldevs(alldevs);
return -1;
}
/* 跳转到选中的适配器 */
for(d=alldevs, i=0; i< inum-1 ;d=d->next, i++);
/* 打开设备 */
if ( (adhandle= pcap_open(d->name, // 设备名
65536, // 65535保证能捕获到不同数据链路层上的每个数据包的全部内容
PCAP_OPENFLAG_PROMISCUOUS, // 混杂模式
1000, // 读取超时时间
NULL, // 远程机器验证
errbuf // 错误缓冲池
) ) == NULL)
{
fprintf(stderr,"\nUnable to open the adapter. %s is not supported by WinPcap\n", d->name);
/* 释放设备列表 */
pcap_freealldevs(alldevs);
return -1;
}
printf("\nlistening on %s...\n", d->description);
/* 释放设备列表 */
pcap_freealldevs(alldevs);
/* 开始捕获 */
pcap_loop(adhandle, 0, packet_handler, NULL);
return 0;
}
/* 每次捕获到数据包时,libpcap都会自动调用这个回调函数 */
void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data)
{
struct tm *ltime;
char timestr[16];
time_t local_tv_sec;
/* 将时间戳转换成可识别的格式 */
local_tv_sec = header->ts.tv_sec;
ltime=localtime(&local_tv_sec);
strftime( timestr, sizeof timestr, "%H:%M:%S", ltime);
printf("%s,%.6d len:%d\n", timestr, header->ts.tv_usec, header->len);
}