我正在尝试为 Windows 10 设置防火墙例外。经过多次搜索后,我将这段代码放在一起:
private const string PROGID_OPEN_PORT = "HNetCfg.FWOpenPort";
private const string CLSID_FIREWALL_MANAGER = "{304CE942-6E39-40D8-943A-B913C40C9CD4}";
private NetFwTypeLib.INetFwMgr GetFirewallManager()
{
Type objectType = Type.GetTypeFromCLSID(
new Guid(CLSID_FIREWALL_MANAGER));
return Activator.CreateInstance(objectType)
as NetFwTypeLib.INetFwMgr;
}
INetFwMgr manager = GetFirewallManager();
Type type = Type.GetTypeFromProgID(PROGID_OPEN_PORT);
INetFwOpenPort port = Activator.CreateInstance(type) as INetFwOpenPort;
port.Name = "MyPortRule";
port.Port = 9600;
port.Scope = NET_FW_SCOPE_.NET_FW_SCOPE_ALL;
port.Protocol = NET_FW_IP_PROTOCOL_.NET_FW_IP_PROTOCOL_TCP;
port.IpVersion = NET_FW_IP_VERSION_.NET_FW_IP_VERSION_ANY;
manager.LocalPolicy.CurrentProfile.GloballyOpenPorts.Add(port);
这确实将防火墙规则放入具有高级安全性的 Windows 防火墙中,但该规则的配置文件设置为公共。将配置文件设置为公开时,防火墙不会让数据通过端口。
使用 Windows UI 修改规则,我确定必须将配置文件设置为“私有”或“任何”,以便数据通过。为什么设置为 NET_FW_SCOPE_.NET_FW_SCOPE_ALL 的 port.Scope 没有将配置文件设置为 Any?您如何将防火墙规则中的配置文件设置为私有或任何?
我还尝试将 port.Scope 设置为 NET_FW_SCOPE_.NET_FW_SCOPE_LOCAL_SUBNET。个人资料仍设置为“公开”。