« | September 2025 | » | 日 | 一 | 二 | 三 | 四 | 五 | 六 | | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | | | | | |
| 登录 |
| 联系我 email: binaryluo(at)gmail.com
Blog信息 |
blog名称:二进制-虚心使人进步,骄傲使人落后。 日志总数:42 评论数量:370 留言数量:88 访问次数:640908 建立时间:2005年2月19日 |

| |
[网络编程技术]【原创】Winpcap学习:第一天(20060125) 原创空间, 随笔, 读书笔记, 心得体会, 软件技术, 电脑与网络
binaryluo 发表于 2006/1/28 15:30:51 |
转载请注明原文出处:http://blogger.org.cn/blog/more.asp?name=binaryluo&id=11458
说明:本系列文章是我阅读winpcap手册后整理的一个学习笔记。文章中出现的所有代码是我根据winpcap手册中的示例代码进行了学习,并调试通过,其中对部分代码作了修改,关于代码的版权我尊重winpcap手册中的版权说明,如果你使用了本系列文章中的代码而引起任何的版权或造成安全威胁等问题,我将不负任何责任。 下载好了WpdPack_3_2_alpha1.zip(下载地址:http://www.winpcap.org/install/bin/WpdPack_3_2_alpha1.zip),解压后除了有文档,例子外还有Include和lib,于是想用TC2来做开发环境,但是编译的时候老是出问题,于是放弃。后来阅读了Winpcap手册后才知道因为是在windows上开发,所以它推荐用VC++6.0,于是改用VC。
第一个试验是:
#include <pcap.h>#include <remote-ext.h>
int main() { pcap_if_t *alldevs; pcap_if_t *d; int i = 0; char errbuf[PCAP_ERRBUF_SIZE];
/* Retrieve the device list from the local machine*/ if (pcap_findalldevs_ex(PCAP_SRC_IF_STRING, NULL /* auth is not needed */, &alldevs, errbuf) == -1) { printf("Error in pcap_findalldevs_ex: %s\n", errbuf); exit(1); }
/* Print the list */ for (d = alldevs; d != NULL; d = d->next) { /* Print the device's name */ printf("%d. %s", ++ i, d->name);
/* Print the device's dscription */ 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; }
/* We don't need any more the device list. Free it */ pcap_freealldevs(alldevs);
return 1;}
编译的时候又遇到问题——“无法打开pcap.h”。又查看开发手册才找到解决方法:
1.安装Winpcap驱动。下载地址:http://www.winpcap.org/install/bin/WinPcap_3_1.exe。
2.将Winpcap的Include,Lib目录添加进VC6.0的环境变量中;
3. 针对每一个项目,先用VC打开项目,然后在"Project->Settings",标签栏出选择"C/C++",在"Preprocessor definitions"的输入框里添加"WPCAP",再选择"Link",在"Object/library modules"的输入框里添加"wpcap.lib Packet.lib"。
再编译时终于OK了。之后,阅读代码并查看开发手册学到了下面的东西:
pcap_if是一个结构体,具体点它是一个链表的结点,他的定义如下:
struct pcap_if {
struct pcap_if *next;
char *name;
char *description;
struct pcap_addr *addresses;
u_int flags;
}
另外,在pcap.h中有一句“typedef struct pcap_if pcap_if_t;”,所以也可以用pcap_if_t代替pcap_if。
int pcap_findalldevs_ex(char * source,
struct pcap_rmtauth * auth,
pcap_if_t ** alldevs,
char * errbuf
)
这个函数是’pcap_findalldevs()’的一个超集。’pcap_findalldevs()’比较老,他只允许列出本地机器上的设备。然而,’pcap_findalldevs_ex()’除了可以列出本地及其上的设备,还可以列出远程机器上的设备。此外,它还能列出所有可用的pcap文件到指定的文件夹。’pcap_findalldevs_ex()’是平台无关的,然而它以来于标准的’pcap_findalldevs()’来获得本地机器的地址。
|
回复:Winpcap学习:第一天(20060125) 原创空间, 随笔, 读书笔记, 心得体会, 软件技术, 电脑与网络
binaryluo发表评论于2006/4/12 14:37:46 |
以下引用feiyu_lili在2006-4-12 11:46:41的评论:
binaryluo第二个问题:列出本地适配器跟远程适配器的区别(作用),本地的就不多说了。
我现在模糊了呢,能不能给我解释一下呢 如果你的机子是多宿主主机,列出本地适配器后你就可以方便的选择要在哪块网卡上捕获数据包。
|
回复:Winpcap学习:第一天(20060125) 原创空间, 随笔, 读书笔记, 心得体会, 软件技术, 电脑与网络
binaryluo发表评论于2006/3/21 11:22:37 |
以下引用limi(游客)在2006-3-20 22:41:24的评论:不会设置呀,哪位大吓帮帮忙,讲详细一点,谢谢!!!
LINK : fatal error LNK1104: cannot open file "wpcap.lib"请看文章:
3.
针对每一个项目,先用VC打开项目,然后在"Project->Settings",标签栏出选择"C/C++",在"Preprocessor
definitions"的输入框里添加"WPCAP",再选择"Link",在"Object/library
modules"的输入框里添加"wpcap.lib Packet.lib"。
|
回复:Winpcap学习:第一天(20060125) 原创空间, 随笔, 读书笔记, 心得体会, 软件技术, 电脑与网络
limi(游客)发表评论于2006/3/20 22:41:24 |
不会设置呀,哪位大吓帮帮忙,讲详细一点,谢谢!!!
LINK : fatal error LNK1104: cannot open file "wpcap.lib"
|
回复:Winpcap学习:第一天(20060125) 原创空间, 随笔, 读书笔记, 心得体会, 软件技术, 电脑与网络
binaryluo发表评论于2006/3/13 21:31:04 |
以下引用sanmao(游客)在2006-3-13 16:20:04的评论:Linking...LIBCD.lib(wincrt0.obj) : error LNK2001: unresolved external symbol _WinMain@16Debug/0.exe : fatal error LNK1120: 1 unresolved externalsError executing link.exe.
我设置好之后编译通过了,但是运行的时候就出现了上面的错误,请问是不是我没设置好,还是 ??链接的时候正常吗??
|
回复:Winpcap学习:第一天(20060125) 原创空间, 随笔, 读书笔记, 心得体会, 软件技术, 电脑与网络
sanmao(游客)发表评论于2006/3/13 16:20:04 |
Linking...LIBCD.lib(wincrt0.obj) : error LNK2001: unresolved external symbol _WinMain@16Debug/0.exe : fatal error LNK1120: 1 unresolved externalsError executing link.exe.
我设置好之后编译通过了,但是运行的时候就出现了上面的错误,请问是不是我没设置好,还是 ??
|
|