windows中filter-hook驱动程序

windows中filter-hook驱动程序

ID:28711887

大小:37.00 KB

页数:6页

时间:2018-12-13

windows中filter-hook驱动程序_第1页
windows中filter-hook驱动程序_第2页
windows中filter-hook驱动程序_第3页
windows中filter-hook驱动程序_第4页
windows中filter-hook驱动程序_第5页
资源描述:

《windows中filter-hook驱动程序》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、实用标准文案Windows中Filter-Hook驱动程序在Windows2000和WindowsXP中,System32drivers目录下的ipfltdrv.sys是Microsoft提供的ip协议过滤驱动程序。它允许用户注册自己的ip数据报处理函数。在MSDN中有关于这方面内容的简短说明,位于Filter-HookDriverReference章节中。这一部分说明文档论述了filter-hook驱程实现的回调函数和该驱程用以注册回调函数的I/O控制码。回调函数是这类驱程的主体部分。操作系统提供的ip过滤驱动程序使用这个过滤钩子来判断ip数据包的处理方式。所注册的过

2、滤钩子是用PacketFilterExtensionPtr数据类型定义的。由于是使用函数的地址而不是函数的名字注册过滤钩子的入口点,所以可以自由的为过滤钩子函数命名。下面分别说明钩子的数据结构和注册该钩子的I/O控制码。PacketFilterExtensionPtr下面是他的定义。typedefPF_FORWARD_ACTION(*PacketFilterExtensionPtr)(unsignedchar*PacketHeader,unsignedchar*Packet,unsignedintPacketLength,unsignedintRecvInterfaceI

3、ndex,unsignedintSendInterfaceIndex,IPAddrRecvLinkNextHop,IPAddrSendLinkNextHop);该类型就是过滤钩子的回调函数,他决定所有传过来的ip数据包的命运,是继续传递,还是丢掉,或者允许ip过滤驱动程序继续处理。1.参数PacketHeader精彩文档实用标准文案指向该数据包的ip头部的指针。Filter-Hook驱动程序可以将其转换为IPHeader结构指针类型。PacketFilter-Hook驱动程序接收到的包含数据包信息的缓冲区指针。该缓冲区不包含PacketHeader指针指向的ip协议头。P

4、acketLength以字节为单位的Packet缓冲区的长度。该长度不包含ip协议头的大小。RecvInterfaceIndex数据包到达的接口适配器的序号。Filter-Hook驱动程序使用该序号访问接收数据包的适配器。对于发送的数据包,该参数为INVALID_PF_IF_INDEX,并且参数RecvLinkNextHop的值没有意义。SendInterfaceIndex数据包发送的接口适配器的序号。如果数据包需要通过该适配器路由,可以通过简单网络协议(SNMP)查询路由表。对于接收的数据包,该参数为INVALID_PF_IF_INDEX,并且参数SendLinkNex

5、tHop的值没有意义。RecvLinkNextHop如果接口适配器是一个多点(绑定多个ip地址?)接口,该参数为适配器接收该数据包时的ip地址。否则,该参数为ZERO_PF_IP_ADDR。SendLinkNextHop如果接口适配器是一个多点(绑定多个ip地址?)接口,该参数为适配器接发送数据包时的ip地址。否则,该参数为ZERO_PF_IP_ADDR。2.返回值返回PF_FORWARD_ACTION枚举类型的值:PF_FORWARD精彩文档实用标准文案该返回值指示ip过滤驱动程序应该立刻将数据包转发到ip协议栈中。如果该数据包是本机需要的数据包,ip协议将其转发给上层

6、协议处理,如果不是到本机的数据包,则ip将路由该数据包(如果此时路由功能被打开)。PF_DROP该返回值指示ip过滤驱动程序将立刻向ip协议栈发出丢弃响应。这时ip协议将丢弃该数据包。PF_PASS该返回值指示ip过滤驱动程序处理该数据包,并将结果动作返回到ip协议栈。如果Filter-Hook驱动程序认为不需要处理该数据包,则应该返回该值。3.注释如果Filter-Hook驱动程序返回PF_PASS,ip过滤驱动程序将处理该数据包。在这种情况下,用户态应用程序可以通过PacketFilteringAPI控制包的过滤动作(iphlpapi.lib)。通过这些API函数可以

7、创建和管理ip数据包的输入输出。每一个ip适配器接口都可以有一个或几个与其相关联的过滤器。过滤器可以包括ip地址,地址掩码,端口号,协议标示符。更多的信息参考PlatformSDK。IP过滤驱动程序可以使用IPHeader结构传递数据包的ip头信息。4.IPHeaderPacketHeader参数指向的缓冲区通常被定义为IPHeader结构。该结构提供了数据包的细节信息。其定义如下:typedefstructiphdr{UCHARiph_verlen;//VersionandlengthUCHARiph_tos;//Typeo

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。