4_WinPcap之打开适配器并捕获数据包(四).docVIP

4_WinPcap之打开适配器并捕获数据包(四).doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
4_WinPcap之打开适配器并捕获数据包(四).doc

前三讲都是一些铺垫,并没有什么实用价值。接下来我将为大家一层一层揭开WinPcap的神秘面纱。WinPcap之打开适配器并捕获数据包。 我们将用到一个新的函数pcap_open(),下面是参数说明 Snaplen: 制定要捕获数据包的那些部分;在一些操作系统中驱动可以被配置成只捕获数据包的初始化部分; Flags : 指示适配器是否被设置为混杂模式;一般情况下适配器只接受发给自己的数据包,而那些在其他机器之间通讯的数据包将会被丢弃,如果适配器是会混杂模式,那么不管这个数据包是不是发给自己的,适配器都会去捕获。即,混在模式下适配器是不会挑食的,它将捕获所有的数据包。 To_ms : 指定读取数据的超时时间;以毫秒计算,在统计模式下,to_ms还可以用来定义统计的时间间隔。将to_ms设置为0,可以理解为没有时间限制,即如果没有数据到达的话,读操作将永远不会返回,如果设置为-1,则情况恰好相反,无论有没有数据包到达,读取操作都会立即的返回。 当适配器被打开,捕获工作就可以用pcap_dispatch()或pcap_loop()进行,这两个函数非常的相似,区别就是pcap_dispctch()当超时时间到了就返回,而pcap_loop()只有当cnt数据包被捕获才会返回 Packet_handler指向一个可以接受数据包的函数。这个函数会在收到一个通用状态时被libcap所调用。数据包的首部一般有一些诸如时间戳,数据包长度的信息,还包含了协议首部的实际数据(冗余校验码CRC不再支持,因为帧到达适配器,并经过校验确认后,适配器会将CRC删除与此同时大部分适配器会直接丢弃CRC错误的数据包,所以WinPcap没办法捕捉到) 完整代码: #define HAVE_REMOTE #include pcap.h /* packet handler 函数原型*/ 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 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 t

文档评论(0)

changlipo2019 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档