我正在尝试为使用NetFwTypeLib库的特定组添加TCP端口1433的防火墙规则。
但是,将端口作为整数转换为字符串或作为简单的“1433”字符串添加到LocalPorts变量中,将返回“值超出范围”异常。
删除端口并仅使用所有端口都可以正常工作。
这是我使用的代码:
bool CreateRule(string sName, string sPort, NET_FW_IP_PROTOCOL_ ProtocolType, string sIpAdress, string sGroup = "")
{
try
{
INetFwRule firewallRule = (INetFwRule)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FWRule"));
firewallRule.Action = NET_FW_ACTION_.NET_FW_ACTION_ALLOW;
firewallRule.Description = "Used to allow Server access.";
firewallRule.Direction = NET_FW_RULE_DIRECTION_.NET_FW_RULE_DIR_IN;
firewallRule.Enabled = true;
firewallRule.Name = sName;
firewallRule.Grouping = sGroup;
firewallRule.LocalPorts = sPort; // "1433" causes out of range exception
firewallRule.RemoteAddresses = sIpAdress;
firewallRule.Protocol = (int)ProtocolType;
INetFwPolicy2 firewallPolicy = (INetFwPolicy2)Activator.CreateInstance(
Type.GetTypeFromProgID("HNetCfg.FwPolicy2"));
firewallPolicy.Rules.Add(firewallRule);
return true;
}
catch
{
return false;
}
}
设置
firewallRule.LocalPorts
成员会导致异常。有人知道出什么事了吗?
最佳答案
您必须将协议(protocol)类型放在端口之前,因此它是有效的。