1.环境配置:
我的环境:WindosXP虚拟机 , Dev C++
这一步需要的内容:
开发环境包:
链接:https://pan.baidu.com/s/155x_BiCf-O0gNLk29_nTWw?pwd=winp
提取码:winp
- Winpcap4.1.3安装包
- Winpcap4.1.2开发者包
- Dev c++安装包
- WS2_32.lib
配置步骤:
1.安装Winpcap4.1.3安装包
2.打开Dev c++,工具——》编译选项——》编译器配置——》目录——》库,点击红框处添加Winpcap开发包中的Lib文件夹
3.继续向"C包含文件"和"C++包含文件"中添加开发者包中的Include文件夹
4.新建一个空项目,点击“项目”——》"项目属性",依照下图添加wpcap.lib和WS2_32.lib
5.复制如下测试代码,测试环境是否配置完成
#define WPCAP
#define HAVE_REMOTE
#include <stdio.h>
#include <stdlib.h>
#include <pcap.h>
#include <remote-ext.h>
int main()
{
pcap_if_t* alldevs, * d;
int i = 0;
char errbuf[PCAP_ERRBUF_SIZE];
if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL,&alldevs, errbuf) == -1)
{
fprintf(stderr, "Error in pcap_findalldevs_ex: %s\n",
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);
}
2.开始编写Winpcap代码
1.首先给出Winpcap中文技术手册网站:WinPcap: WinPcap 中文技术手册 (bacysoft.cn)
2.其中的"循序渐进教您使用WinPcap"中,有着许多翔实的代码案例,但在实际运行中可能回遇到一些环境问题,于是我对于部分代码,给出我修改后可以运行的版本:
3.打开适配器并捕获数据包:
#define WPCAP
#define HAVE_REMOTE
#include <stdio.h>
#include <stdlib.h>
#include <pcap.h>
#include <remote-ext.h>
#include <winsock.h>
#include <time.h>
void packet_handler(u_char *param, const struct pcap_pkthdr *header, const u_char *pkt_data);
int 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