我正在尝试使用以下过滤器来转移包,但失败了:
WinDivertOpen("IfIdx == X", WINDIVERT_LAYER::WINDIVERT_LAYER_NETWORK, 0, 0);
我正在尝试一个程序,它必须从索引为X (0,1,2,...)的特定接口转移流量。但是我得到了一个错误代码号87,这表明一个无效的包过滤器字符串、层、优先级或标志。
如果我尝试使用其他过滤器,如"tcp“,它可以工作,但我只需要将过滤器应用于我已经知道其索引的特定接口。如果此筛选键不起作用..我能做些什么呢?
下面是文档:https://reqrypt.org/windivert-doc.html#filter_language
致以问候和感谢。
编辑:我也尝试过这个:
handle = WinDivertOpen("true", WINDIVERT_LAYER::WINDIVERT_LAYER_NETWORK, 0, 0);
if (handle == INVALID_HANDLE_VALUE)
printf("ERROR WINDIVERT: %d", GetLastError());
else
{
while (TRUE)
{
if (WinDivertRecv(handle, packet, sizeof(packet), &addr, &packetLen))
{
if (addr.IfIdx != X)
{
WinDivertSend(handle, packet, packetLen, &addr, NULL);
}
}
}
WinDivertClose(handle);
但它阻止了所有接口的流量,并且不仅阻止了我的索引为X的特定接口的流量。
发布于 2017-03-25 20:35:57
我认为问题在于,当正确的标记是ifIdx
(小写i
)时,您使用的是IfIdx
。顺便说一句,如果你升级到WinDivert1.2,你可以使用WinDivertHelperCheckFilter
函数来获得更有用的错误信息。
至于你的编辑,可能有很多问题,比如在WinDivertSend
之前没有重新计算校验和(如果有必要)。请参阅passthru.c
示例程序。
https://stackoverflow.com/questions/42855206
复制相似问题