PF_FILTER_DESCRIPTOR的正确用法(XP)

问题终于解决了,是PfBindInterfaceToIPAddress没有绑定对,网上关于PF_FILTER_DESCRIPTOR的用法几乎都是以讹传讹,存在各种错误。现在将我在VS2005上编译,工作正常的代码发出来,避免学习者再走弯路!

void Ctestfirewall01Dlg::OnBnClickedButton1()
{
 // TODO: 在此添加控件通知处理程序代码
 // 一个创建网络包过滤接口
    INTERFACE_HANDLE hInterface;
    PfCreateInterface(0,
    PF_ACTION_FORWARD,
    PF_ACTION_FORWARD,
    FALSE,
    TRUE,
    &hInterface);

        //从2个IP地址控件读出dwIP和srIP的值,为10位的整数
 this->UpdateData(true);

        //一定要这么转换才能作为infilter的参数传入
 ULONG uldsIP=htonl(dwIP);
 ULONG ulsrIP=htonl(srIP);

 //获得本机IP地址,绑定一定要用这个
 //#include <Iphlpapi.h>
 DWORD dwLocalIP;
 dwLocalIP=0;
 PIP_ADAPTER_INFO pAdapterInfo = NULL;
 ULONG ulLen = 0;
 ::GetAdaptersInfo(pAdapterInfo,&ulLen);
 pAdapterInfo = (PIP_ADAPTER_INFO)::GlobalAlloc(GPTR, ulLen);
 if(::GetAdaptersInfo(pAdapterInfo,&ulLen) ==  ERROR_SUCCESS)
 {
  if(pAdapterInfo != NULL)
  {
   dwLocalIP = ::inet_addr(pAdapterInfo->IpAddressList.IpAddress.String);
   
  }
  
 }

 if(NO_ERROR!=PfBindInterfaceToIPAddress(hInterface, PF_IPV4,(PBYTE)&dwLocalIP))
  MessageBox("bind error");

    // 现在我们开始过滤HTTP协议的的接口
    FILTER_HANDLE fHandle;
    // 填充过滤包的规则结构
    PF_FILTER_DESCRIPTOR inFilter;
    inFilter.dwFilterFlags = FD_FLAGS_NOSYN; //一直添这个值
    inFilter.dwRule = 0; //一直添这个值
    inFilter.pfatType = PF_IPV4; //用 ipV4 地址


     inFilter.SrcAddr =(PBYTE)&ulsrIP;
     inFilter.DstAddr =(PBYTE)&uldsIP;

     //源IP地址要ANY,目标IP地址根据实际的来
     inFilter.wSrcPort = FILTER_TCPUDP_PORT_ANY;
     inFilter.wDstPort = 80;

     inFilter.wSrcPortHighRange = inFilter.wSrcPort; 
     inFilter.wDstPortHighRange = inFilter.wDstPort;
     inFilter.dwProtocol = FILTER_PROTO_TCP; // 过滤的协议

     inFilter.SrcMask = (PBYTE)"/xff/xff/xff/xff"; //设置本地子网掩码
     inFilter.DstMask = (PBYTE)"/xff/xff/xff/xff";

     inFilter.fLateBound = LB_SRC_ADDR_USE_DSTADDR_FLAG|LB_DST_ADDR_USE_DSTADDR_FLAG;
 
        // 加入一个过滤接口,实践证明,过滤来自外部的连接infilter是应该放在第四个参数,而不是msdn上说的第二个
    PfAddFiltersToInterface(hInterface, 0, NULL, 1, &inFilter, &fHandle);

    // 请在这设置一个调试断点
    // 移除过滤接口
    PfRemoveFilterHandles(hInterface, 1, &fHandle);
    PfUnBindInterface(hInterface);
    PfDeleteInterface(hInterface);
}


PS:防火墙功能是防止外部对本机的连接。但是源IP地址需要设为本机,目的IP地址设为客户机,这个概念比较容易混淆。

libusb_get_string_descriptor_ascii()函数用于获取设备的字符串描述符。它的函数原型如下: ```c int libusb_get_string_descriptor_ascii( libusb_device_handle *dev_handle, uint8_t desc_index, unsigned char *data, int length ); ``` 参数说明: - `dev_handle`:libusb设备句柄,可以通过libusb_open()函数打开设备获取。 - `desc_index`:字符串描述符的索引,通常是设备描述符中的字符串描述符索引字段(例如,`iManufacturer`、`iProduct`、`iSerialNumber`)。 - `data`:用于存储字符串描述符数据的缓冲区。 - `length`:缓冲区的长度。 该函数将指定索引的字符串描述符数据复制到提供的缓冲区中,并返回实际复制的字节数。如果成功,返回值为0;如果失败,返回负数错误代码。 以下是一个使用libusb_get_string_descriptor_ascii()函数获取设备制造商字符串描述符的示例代码: ```c #include <stdio.h> #include <libusb-1.0/libusb.h> int main() { libusb_context *ctx = NULL; libusb_device_handle *dev_handle = NULL; int r; r = libusb_init(&ctx); if (r < 0) { printf("Failed to initialize libusb\n"); return 1; } dev_handle = libusb_open_device_with_vid_pid(ctx, vendor_id, product_id); if (dev_handle == NULL) { printf("Failed to open device\n"); libusb_exit(ctx); return 1; } unsigned char manufacturer[256]; r = libusb_get_string_descriptor_ascii(dev_handle, desc_index, manufacturer, sizeof(manufacturer)); if (r < 0) { printf("Failed to get manufacturer string descriptor\n"); libusb_close(dev_handle); libusb_exit(ctx); return 1; } printf("Manufacturer: %s\n", manufacturer); libusb_close(dev_handle); libusb_exit(ctx); return 0; } ``` 在上述示例中,您需要将`vendor_id`和`product_id`替换为您要打开的设备的实际供应商ID和产品ID。另外,您还需要将`desc_index`替换为设备描述符中制造商字符串描述符的索引。 希望这能帮到您!
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值