深度剖析WinPcap之(八)――打开与关闭适配器(5)_第1页
深度剖析WinPcap之(八)――打开与关闭适配器(5)_第2页
深度剖析WinPcap之(八)――打开与关闭适配器(5)_第3页
深度剖析WinPcap之(八)――打开与关闭适配器(5)_第4页
深度剖析WinPcap之(八)――打开与关闭适配器(5)_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、深度剖析WinPcap之(八打开与关闭适配器(5 2009-09-24 20:30:35标签:WinPcap 打开 关闭 适配器推送到技术圈 版权声明:原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。     pcap_activate_win32函数在函数pcap_create(中把p->activate_op操作句柄设为 pcap_activate_win32(函数。函数pcap_activate_win32(为激活捕捉实例做各种准备工作。函数的主要代码如下:static int pcap

2、_activate_win32(pcap_t *pNetType type;/* 初始化WinSock*/wsockinit(;/*调用packet.dll的函数PacketOpenAdapter(打开适配器*/p->adapter = PacketOpenAdapter(p->opt.source;if (p->adapter = NULL/错误,函数返回/*调用packet.dll的函数PacketGetNetType(获取网络类型*/if(PacketGetNetType (p->adapter,&type = FALSE/错误,函数返回/*设置链路类型*

3、/switch (type.LinkType case NdisMediumWan:p->linktype = DLT_EN10MB;break;case NdisMedium802_3:p->linktype = DLT_EN10MB;/* 这大概是一个真正的以太网捕获;给它数据链路层类型链表设置为DLT_EN10MB与 DLT_DOCSIS,因此一个应用程序可以让你选择它的类型,以防万一正在捕获DOCSIS网络数据包,是由一个Cisco网线调制器终端系统发送到以太网上的(它不发送一个以太网协议头到线上,而是发送原始的DOCSIS数据帧到线上)。*/p->dlt_list

4、= (u_int * malloc(sizeof(u_int * 2;/*如果分配失败,仅留下空链表*/if (p->dlt_list != NULL p->dlt_list0 = DLT_EN10MB;p->dlt_list1 = DLT_DOCSIS;p->dlt_count = 2;break;default:p->linktype = DLT_EN10MB; /*一个未知的适配器假定为以太网适配器*/break;/* 设置网络适配器的过滤模式为混杂模式*/if (p->misc /混杂模式if (PacketSetHwFilter(p-

5、>adapter,NDIS_PACKET_TYPE_PROMISCUOUS = FALSE/错误,函数返回else /非混杂模式if (PacketSetHwFilter(p->adapter,NDIS_PACKET_TYPE_ALL_LOCAL = FALSE/错误,函数返回/*设置pcap_t结构体中的缓冲区大小*/p->bufsize = WIN32_DEFAULT_USER_BUFFER_SIZE;/*分配在捕获过程中使用的数据包结构体*/if(p->Packet = PacketAllocatePacket(=NULL/错误,函数返回if(!(p->ad

6、apter->Flags & INFO_FLAG_DAG_CARD/* * 传统的适配器*/* 如果缓冲区的大小不是显式的设定,默认为 WIN32_DEFAULT_USER_BUFFER_SIZE。*/if (p->opt.buffer_size = 0p->opt.buffer_size = WIN32_DEFAULT_KERNEL_BUFFER_SIZE;/设置内核NPF的缓冲区if(PacketSetBuff(p->adapter,p->opt.buffer_size=FALSE/错误,函数返回p->buffer = (u_char *mall

7、oc(p->bufsize;if (p->buffer = NULL /错误,函数返回/*初始化捕获过程中使用的数据包结构体*/PacketInitPacket(p->Packet,(BYTE*p->buffer,p->bufsize;/* 告诉驱动程序 只有存储了至少16K的数据后,才能复制数据*/if(PacketSetMinToCopy(p->adapter,16000=FALSE/错误,函数返回/*设置读取超时时间*/PacketSetReadTimeout(p->adapter, p->md.timeout;/*设置常规的NPF进行读取

8、与设置过滤的操作句柄*/p->read_op = pcap_read_win32_npf;p->setfilter_op = pcap_setfilter_win32_npf;p->setdirection_op = NULL; /*没有实现*/p->inject_op = pcap_inject_win32;/* 发送单个数据包的操作*/p->set_datalink_op = NULL; /*不能改变数据链路层的类型*/p->getnonblock_op = pcap_getnonblock_win32;p->setnonblock_op = pc

9、ap_setnonblock_win32;p->stats_op = pcap_stats_win32;p->setbuff_op = pcap_setbuff_win32;p->setmode_op = pcap_setmode_win32;p->setmintocopy_op = pcap_setmintocopy_win32;p->cleanup_op = pcap_cleanup_win32;return (0;bad:pcap_cleanup_win32(p;return (PCAP_ERROR;函数首先调用wsockinit(函数初始化WinSock,

10、然后调用packet.dll提供的函数PacketOpenAdapter(打开适配器。接着调用packet.dll提供的函数PacketGetNetType(获取网络类型。根据网络类型设置链路类型。此处我们只分析常规的以太网捕获。接下来调用packet.dll提供的函数PacketSetHwFilter(设置网络适配器的过滤模式为混杂模式。然后设置用户层与内核捕获数据的缓冲区大小分别为WIN32_DEFAULT_USER_BUFFER_SIZE(256KB与WIN32_DEFAULT_KERNEL_BUFFER_SIZE(1MB,并设置内核缓冲区,分配用户缓冲区,并进行初始化。设置驱动程序只有

11、存储了至少16K的数据后,才能复制数据到用户空间,设置读取超时时间。设置NPF进行读取的操作句柄为pcap_read_win32_npf(函数与设置过滤的操作句柄为pcap_setfilter_win32_npf函数。设置发送单个数据包的操作句柄为pcap_inject_win32函数。设置下列函数句柄。 p->getnonblock_op = pcap_getnonblock_win32;p->setnonblock_op = pcap_setnonblock_win32;p->stats_op = pcap_stats_win32;p->setbuff_op = pcap_setbuff_win32;p->setmode_op = pcap_setmode_win32;p->setmintocopy_op = pcap_setmintocopy_win32;p->cleanup_op = pcap_cleanup_win3

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论