在C#中如何设置防火墙规则-创新互联

在C#中如何设置防火墙规则?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

目前成都创新互联已为成百上千家的企业提供了网站建设、域名、虚拟主机、网站托管维护、企业网站设计、孟津网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。

创建规则的方法:


/// <summary>
/// 为WindowsDefender防火墙添加一条通信端口出站规则
/// </summary>
/// <param name="type">规则类型</param>
/// <param name="ruleName">规则名称</param>
/// <param name="appPath">应用程序完整路径</param>
/// <param name="localAddresses">本地地址</param>
/// <param name="localPorts">本地端口</param>
/// <param name="remoteAddresses">远端地址</param>
/// <param name="remotePorts">远端端口</param>
public static bool CreateOutRule(NET_FW_IP_PROTOCOL_ type, string ruleName, string appPath, string localAddresses = null, string localPorts = null, string remoteAddresses = null, string remotePorts = null)
{
  //创建防火墙策略类的实例
  INetFwPolicy2 policy2 = (INetFwPolicy2)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FwPolicy2"));
  //检查是否有同名规则
  foreach (INetFwRule item in policy2.Rules)
  {
    if (item.Name == ruleName)
    {
      return true;
    }
  }
  //创建防火墙规则类的实例: 有关该接口的详细介绍:/tupian/20230522/nn-netfw-inetfwrule
  INetFwRule rule = (INetFwRule)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FwRule"));
  //为规则添加名称
  rule.Name = ruleName;
  //为规则添加描述
  rule.Description = "禁止程序访问非指定端口";
  //选择入站规则还是出站规则,IN为入站,OUT为出站
  rule.Direction = NET_FW_RULE_DIRECTION_.NET_FW_RULE_DIR_OUT;
  //为规则添加协议类型
  rule.Protocol = (int)type;
  //为规则添加应用程序(注意这里是应用程序的绝对路径名)
  rule.ApplicationName = appPath;
  //为规则添加本地IP地址  
  if (!string.IsNullOrEmpty(localAddresses))
  {
    rule.LocalAddresses = localAddresses;
  }

  //为规则添加本地端口
  if (!string.IsNullOrEmpty(localPorts))
  {
    //需要移除空白字符(不能包含空白字符,下同)
    rule.LocalPorts = localPorts.Replace(" ", "");// "1-29999, 30003-33332, 33334-55554, 55556-60004, 60008-65535";
  }
  //为规则添加远程IP地址
  if (!string.IsNullOrEmpty(remoteAddresses))
  {
    rule.RemoteAddresses = remoteAddresses;
  }
  //为规则添加远程端口
  if (!string.IsNullOrEmpty(remotePorts))
  {
    rule.RemotePorts = remotePorts.Replace(" ", "");
  }
  //设置规则是阻止还是允许(ALLOW=允许,BLOCK=阻止)
  rule.Action = NET_FW_ACTION_.NET_FW_ACTION_BLOCK;
  //分组 名
  rule.Grouping = "GroupsName";

  rule.InterfaceTypes = "All";
  //是否启用规则
  rule.Enabled = true;
  try
  {
    //添加规则到防火墙策略
    policy2.Rules.Add(rule);
  }
  catch (Exception e)
  {
    string error = $"防火墙添加规则出错:{ruleName} {e.Message}";
    AppLog.Error(error);
    throw new Exception(error);
  }
  return true;
}

本文标题:在C#中如何设置防火墙规则-创新互联
网站网址:https://www.cdcxhl.com/article34/csdpse.html

成都网站建设公司_创新互联,为您提供云服务器网站排名电子商务手机网站建设品牌网站设计ChatGPT

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都定制网站建设