簡體   English   中英

C# - 使用 INetFwPolicy2 添加的 Windows 防火牆規則無效

[英]C# - Windows firewall rule added using INetFwPolicy2 not in effect

我正在使用以下 C# 代碼編寫在 Windows 上運行的服務器程序。

Type tNetFwPolicy2 = Type.GetTypeFromProgID("HNetCfg.FwPolicy2");
INetFwPolicy2 fwPolicy2 = (INetFwPolicy2)Activator.CreateInstance(tNetFwPolicy2);
foreach (INetFwRule2 rule in fwPolicy2.Rules)
{
    if (rule.Name == ruleName)
    {
        if (!rule.Enabled)
        {
            rule.Enabled = true;
        }
        return;
    }
}
INetFwRule2 inboundRule = (INetFwRule2)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FWRule"));
inboundRule.Enabled = true;
inboundRule.Action = NET_FW_ACTION_.NET_FW_ACTION_ALLOW;
inboundRule.Protocol = (int)NET_FW_IP_PROTOCOL_.NET_FW_IP_PROTOCOL_TCP;
inboundRule.LocalPorts = "8080";
inboundRule.Name = ruleName;               // ruleName is the name of the assembly
inboundRule.ApplicationName = progName;    // progName is the full path to the executable
fwPolicy2.Rules.Add(inboundRule);

這段代碼能夠向 Windows 10 添加防火牆規則,該規則顯示在 Window 10 防火牆和高級安全對話框中。 但是,啟用此規則后,我的應用程序仍然無法偵聽來自本地網絡內其他設備的請求。 僅當規則是未指定允許程序的端口規則時才有效。 我應該如何配置它以便規則只允許我的應用程序偵聽網絡請求?

嘗試這個

 INetFwRule firewallRule = Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FWRule")) as INetFwRule;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM