• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

c# 防火墙添加/删除 特定端口的示例

c# 搞代码 4年前 (2022-01-09) 15次浏览 已收录 0个评论

针对将特定端口加入到windows系统的防火墙中,使其允许或禁止通过防火墙。其大概思路是:

/// <summary>
 /// 添加防火墙例外端口
 /// </summary>
 /// <param name="name">名称</param>
 /// <param name="port">端口</param>
 /// <param name="protocol">协议(TCP、UDP)</param>
 /// <param name="scope">范围类型</param>
 /// <param name="remoteAddresses">自定义范围时的IP地址范围</param>
 public static void AllowPortsUseFirewall(string name, int port, string protocol, NET_FW_SCOPE_ scope,string remoteAddresses)
 {
   //创建firewall管理类的实例: Type的GetTypeFromProgID是通过注册表信息项目创建实例类型
   INetFwMgr netFwMgr = (INetFwMgr)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FwMgr")<strong>本文来源gaodai#ma#com搞@代~码^网+</strong>);

   //判断网络类型,是TCP还是UDP
   NET_FW_IP_PROTOCOL_ protocolType = NET_FW_IP_PROTOCOL_.NET_FW_IP_PROTOCOL_UDP;
   if (protocol.ToUpper() == "TCP")
   {
     protocolType = NET_FW_IP_PROTOCOL_.NET_FW_IP_PROTOCOL_TCP;
   }
   //查找以前是否有相同的规则创建,如果有则不再创建新的规则
   foreach (INetFwOpenPort mPort in netFwMgr.LocalPolicy.CurrentProfile.GloballyOpenPorts)
   {
     if (mPort.Protocol == protocolType && mPort.Port == port)
     {
       return;
     }
   }
   //创建一个防火墙端口管理实例
   INetFwOpenPort objPort = (INetFwOpenPort)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FwOpenPort"));
   //设置端口实例名称
   objPort.Name = name;
   //设置端口信息
   objPort.Port = port;
   //端口管理的网络类型
   objPort.Protocol = protocolType;
   /*
   *   NET_FW_SCOPE_ALL 范围是所有地址。 
   *   NET_FW_SCOPE_CUSTOM 自定义范围。 
   *   NET_FW_SCOPE_LOCAL_SUBNET 范围是本地子网。
   *   NET_FW_SCOPE_MAX 使用仅用于测试。不意味着为应用程序实现。 
   */
   //端口的范围,针对哪类或哪个IP地址
   objPort.Scope = scope;
   //此处可以指定IP地址版本信息
   //objPort.IpVersion = NET_FW_IP_VERSION_.NET_FW_IP_VERSION_V4;
   //自定义IP地址范围
   if (objPort.Scope == NET_FW_SCOPE_.NET_FW_SCOPE_CUSTOM)
   {
     //这而需要移除多个地址之间的空白字符串,有空白字符串会出现设置异常
     objPort.RemoteAddresses = remoteAddresses.Replace(" ", ""); ;//"192.168.1.10,192.168.1.12.......";
   }
   //是否启用规则
   objPort.Enabled = true;
   //加入到本地防火墙管理规则中。
   netFwMgr.LocalPolicy.CurrentProfile.GloballyOpenPorts.Add(objPort);
 }

删除规则比较简单:创建防火墙实例,直接移除某种通信类型的端口就行。

/// <summary>
 /// 删除防火墙例外端口
 /// </summary>
 /// <param name="port">端口</param>
 /// <param name="protocol">协议(TCP、UDP)</param>
public static void DeletePortsUseFirewall(int port, string protocol)
{
  //创建firewall管理类的实例: Type的GetTypeFromProgID是通过注册表信息项目创建实例类型
  INetFwMgr netFwMgr = (INetFwMgr)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FwMgr"));
  //移除特定类型的通信方式的端口
  if (protocol == "TCP")
  {
    netFwMgr.LocalPolicy.CurrentProfile.GloballyOpenPorts.Remove(port, NET_FW_IP_PROTOCOL_.NET_FW_IP_PROTOCOL_TCP);
  }
  else
  {
    netFwMgr.LocalPolicy.CurrentProfile.GloballyOpenPorts.Remove(port, NET_FW_IP_PROTOCOL_.NET_FW_IP_PROTOCOL_UDP);
  }
}

以上就是c# 防火墙添加/删除特定端口的示例的详细内容,更多关于c# 防火墙添加/删除端口的资料请关注搞代码其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:c# 防火墙添加/删除 特定端口的示例
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址