午夜视频在线观看区二区-午夜视频在线观看视频-午夜视频在线观看视频在线观看-午夜视频在线观看完整高清在线-午夜视频在线观看网站-午夜视频在线观看亚洲天堂

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

C#如何判斷Windows系統防火墻服務已經開啟并在使用中,如果不在使用中如何重新開啟

admin
2025年3月14日 12:12 本文熱度 119

在C#中判斷Windows防火墻服務是否運行并啟用,可以通過以下步驟實現:

  1. 檢查防火墻服務狀態:確認Windows Firewall服務(MpsSvc)是否正在運行。

  2. 檢查防火墻配置:通過COM接口INetFwPolicy2查詢各網絡配置文件的防火墻啟用狀態。

以下是實現代碼:

using System;

using System.ServiceProcess;

using System.Runtime.InteropServices;


public class FirewallStatusChecker

{

    public static bool IsFirewallEnabledAndRunning()

    {

        // 檢查防火墻服務是否運行

        if (!IsFirewallServiceRunning())

            return false;


        // 檢查防火墻是否啟用

        try

        {

            return IsFirewallEnabled();

        }

        catch (COMException)

        {

            // 處理COM異常(如權限不足)

            return false;

        }

    }


    private static bool IsFirewallServiceRunning()

    {

        try

        {

            using (ServiceController sc = new ServiceController("MpsSvc"))

            {

                return sc.Status == ServiceControllerStatus.Running;

            }

        }

        catch (InvalidOperationException)

        {

            // 服務不存在或無法訪問

            return false;

        }

    }


    private static bool IsFirewallEnabled()

    {

        INetFwPolicy2 firewallPolicy = null;

        try

        {

            // 創建防火墻策略實例

            Type type = Type.GetTypeFromProgID("HNetCfg.FwPolicy2");

            firewallPolicy = (INetFwPolicy2)Activator.CreateInstance(type);


            // 檢查各配置文件的啟用狀態

            bool domain = firewallPolicy.FirewallEnabled(NET_FW_PROFILE_TYPE2.NET_FW_PROFILE2_DOMAIN);

            bool privateProfile = firewallPolicy.FirewallEnabled(NET_FW_PROFILE_TYPE2.NET_FW_PROFILE2_PRIVATE);

            bool publicProfile = firewallPolicy.FirewallEnabled(NET_FW_PROFILE_TYPE2.NET_FW_PROFILE2_PUBLIC);


            return domain || privateProfile || publicProfile;

        }

        finally

        {

            if (firewallPolicy != null)

                Marshal.ReleaseComObject(firewallPolicy);

        }

    }


    [ComImport]

    [Guid("E2B3C97F-6AE1-41AC-817A-F6F92166D7DD")]

    private interface INetFwPolicy2

    {

        [DispId(7)]

        bool FirewallEnabled(NET_FW_PROFILE_TYPE2 profileType);

    }


    private enum NET_FW_PROFILE_TYPE2

    {

        NET_FW_PROFILE2_DOMAIN = 0x1,

        NET_FW_PROFILE2_PRIVATE = 0x2,

        NET_FW_PROFILE2_PUBLIC = 0x4,

        NET_FW_PROFILE2_ALL = 0x7FFFFFFF

    }

}

代碼說明

  1. 服務狀態檢查:使用ServiceController類檢查“MpsSvc”服務的運行狀態。

  2. COM接口調用:通過HNetCfg.FwPolicy2創建防火墻策略對象,查詢各網絡配置文件(域、專用、公共)的防火墻啟用狀態。

  3. 異常處理:捕獲可能的異常,如服務不存在或權限不足。

注意事項

  • 管理員權限:訪問防火墻設置可能需要以管理員身份運行程序。

  • 系統兼容性INetFwPolicy2接口適用于Windows Vista及以上版本。

調用IsFirewallEnabledAndRunning()方法,返回true表示防火墻服務已啟用并運行。


如果檢測到不在使用,開啟防火墻服務并且啟動使用代碼如下:

using System;

using System.ServiceProcess;

using System.Runtime.InteropServices;

using System.Security.Principal;


public class FirewallController

{

    // 主方法:開啟防火墻服務并啟用策略

    public static void EnableFirewall()

    {

        if (!IsRunAsAdmin())

        {

            Console.WriteLine("需要以管理員權限運行!");

            return;

        }


        try

        {

            // 1. 啟動防火墻服務

            StartFirewallService();


            // 2. 啟用防火墻策略

            SetFirewallStatus(true);

        }

        catch (Exception ex)

        {

            Console.WriteLine($"操作失敗: {ex.Message}");

        }

    }


    // 檢查管理員權限

    private static bool IsRunAsAdmin()

    {

        WindowsIdentity identity = WindowsIdentity.GetCurrent();

        WindowsPrincipal principal = new WindowsPrincipal(identity);

        return principal.IsInRole(WindowsBuiltInRole.Administrator);

    }


    // 啟動Windows防火墻服務

    private static void StartFirewallService()

    {

        using (ServiceController sc = new ServiceController("MpsSvc"))

        {

            if (sc.Status != ServiceControllerStatus.Running)

            {

                Console.WriteLine("正在啟動防火墻服務...");

                sc.Start();

                sc.WaitForStatus(ServiceControllerStatus.Running, TimeSpan.FromSeconds(30));

                Console.WriteLine("服務已啟動");

            }

        }

    }


    // 設置防火墻啟用狀態

    private static void SetFirewallStatus(bool enable)

    {

        INetFwPolicy2 firewallPolicy = null;

        try

        {

            Type type = Type.GetTypeFromProgID("HNetCfg.FwPolicy2");

            firewallPolicy = (INetFwPolicy2)Activator.CreateInstance(type);


            // 設置所有配置文件的狀態

            firewallPolicy.FirewallEnabled[NET_FW_PROFILE_TYPE2.NET_FW_PROFILE2_DOMAIN] = enable;

            firewallPolicy.FirewallEnabled[NET_FW_PROFILE_TYPE2.NET_FW_PROFILE2_PRIVATE] = enable;

            firewallPolicy.FirewallEnabled[NET_FW_PROFILE_TYPE2.NET_FW_PROFILE2_PUBLIC] = enable;


            Console.WriteLine(enable ? "防火墻已啟用" : "防火墻已禁用");

        }

        finally

        {

            if (firewallPolicy != null)

                Marshal.ReleaseComObject(firewallPolicy);

        }

    }


    // COM接口定義

    [ComImport]

    [Guid("E2B3C97F-6AE1-41AC-817A-F6F92166D7DD")]

    private interface INetFwPolicy2

    {

        [DispId(7)]

        bool FirewallEnabled(NET_FW_PROFILE_TYPE2 profileType);


        [DispId(7)]

        void FirewallEnabled(NET_FW_PROFILE_TYPE2 profileType, [MarshalAs(UnmanagedType.Bool)] bool enabled);

    }


    private enum NET_FW_PROFILE_TYPE2

    {

        NET_FW_PROFILE2_DOMAIN = 0x1,

        NET_FW_PROFILE2_PRIVATE = 0x2,

        NET_FW_PROFILE2_PUBLIC = 0x4,

        NET_FW_PROFILE2_ALL = 0x7FFFFFFF

    }

}

使用說明:

  1. 需要以管理員權限運行程序(右鍵 -> 以管理員身份運行)

  2. 調用入口方法:

FirewallController.EnableFirewall();

代碼功能分解:

  1. 權限驗證

    • IsRunAsAdmin() 方法驗證當前是否以管理員權限運行

  2. 服務控制

    • 使用ServiceController啟動"MpsSvc"服務

    • 設置30秒超時等待服務啟動

  3. 防火墻策略控制

    • 通過COM接口INetFwPolicy2設置三個網絡配置文件的啟用狀態

    • 同時啟用:域網絡、專用網絡、公用網絡配置

  4. 錯誤處理

    • 捕獲服務操作和COM接口異常

    • 輸出明確的錯誤信息

注意事項:

  1. 系統兼容性

    • 僅支持Windows Vista及更新版本

    • 需要.NET Framework 3.5+

  2. 依賴項

    • 需要防火墻服務存在且未被禁用

    • 需要Windows防火墻組件未被卸載

  3. 權限要求

    • 需要SeLoadDriverPrivilegeSeSecurityPrivilege權限

    • 需要UAC管理員批準模式

如果需要更細粒度的控制(如單獨設置某個配置文件),可以修改SetFirewallStatus方法,添加參數指定具體配置文件類型。


該文章在 2025/3/14 12:12:44 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 国产精品免费区二区三区观看 | 国产高清女同学巨大乳在线观看 | 91夜色精品国产 | 国产欧洲一区二区在线观看 | 1024在线视频精品观看 | 国产一区鲁鲁在线视频免费播放 | 国产一区二区三区在线观看免费 | 国产成人aⅴ片在线 | 成人精品高清视频在线观看 | 国产美女黄性色 | 91久久精品在这里色伊人64 | 国产做爰片久久毛片片美国 | 国产成人在线免费网站 | 国产女人喷浆抽搐高潮视频 | 国产在线精品福利91啪 | 国产精品自拍三级片 | 99久久久久精品一级毛片 | 精品99一区二区三区 | 国模少妇无码一区二区三区 | 国产麻豆剧传媒精品国产v精品 | 99久久这里只精品国产免费 | 国产人妖一区二区在线观看 | 2025国内自拍视频在线播放 | 成人三级视频在线观看一区二区 | 国产亚洲日韩在线播放人成 | 国产孕妇直播在线观看 | 东京一本到熟无码免费视频 | 91天天综合丝袜内裤高跟鞋 | 精品国产三级黄色片 | 成人在线日韩 | av中文字幕网免费 | 91精品国产自产永久观看在线 | 国产狂喷潮在线观看视频欧美 | 精品无码永久在线 | 国产一级毛片网站 | 国产精品久免 | 国产麻豆md传媒视频 | 国产精品人成在线 | 国产91丝袜在线播放动漫蜜月 | 成人免费一级毛片在线播放视频 | 国产麻豆成人 |