狠狠色丁香婷婷综合尤物/久久精品综合一区二区三区/中国有色金属学报/国产日韩欧美在线观看 - 国产一区二区三区四区五区tv

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

C#如何判斷Windows系統(tǒng)防火墻服務(wù)已經(jīng)開(kāi)啟并在使用中,如果不在使用中如何重新開(kāi)啟

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

在C#中判斷Windows防火墻服務(wù)是否運(yùn)行并啟用,可以通過(guò)以下步驟實(shí)現(xiàn):

  1. 檢查防火墻服務(wù)狀態(tài):確認(rèn)Windows Firewall服務(wù)(MpsSvc)是否正在運(yùn)行。

  2. 檢查防火墻配置:通過(guò)COM接口INetFwPolicy2查詢各網(wǎng)絡(luò)配置文件的防火墻啟用狀態(tài)。

以下是實(shí)現(xiàn)代碼:

using System;

using System.ServiceProcess;

using System.Runtime.InteropServices;


public class FirewallStatusChecker

{

    public static bool IsFirewallEnabledAndRunning()

    {

        // 檢查防火墻服務(wù)是否運(yùn)行

        if (!IsFirewallServiceRunning())

            return false;


        // 檢查防火墻是否啟用

        try

        {

            return IsFirewallEnabled();

        }

        catch (COMException)

        {

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

            return false;

        }

    }


    private static bool IsFirewallServiceRunning()

    {

        try

        {

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

            {

                return sc.Status == ServiceControllerStatus.Running;

            }

        }

        catch (InvalidOperationException)

        {

            // 服務(wù)不存在或無(wú)法訪問(wèn)

            return false;

        }

    }


    private static bool IsFirewallEnabled()

    {

        INetFwPolicy2 firewallPolicy = null;

        try

        {

            // 創(chuàng)建防火墻策略實(shí)例

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

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


            // 檢查各配置文件的啟用狀態(tài)

            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

    }

}

代碼說(shuō)明

  1. 服務(wù)狀態(tài)檢查:使用ServiceController類(lèi)檢查“MpsSvc”服務(wù)的運(yùn)行狀態(tài)。

  2. COM接口調(diào)用:通過(guò)HNetCfg.FwPolicy2創(chuàng)建防火墻策略對(duì)象,查詢各網(wǎng)絡(luò)配置文件(域、專用、公共)的防火墻啟用狀態(tài)。

  3. 異常處理:捕獲可能的異常,如服務(wù)不存在或權(quán)限不足。

注意事項(xiàng)

  • 管理員權(quán)限:訪問(wèn)防火墻設(shè)置可能需要以管理員身份運(yùn)行程序。

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

調(diào)用IsFirewallEnabledAndRunning()方法,返回true表示防火墻服務(wù)已啟用并運(yùn)行。


如果檢測(cè)到不在使用,開(kāi)啟防火墻服務(wù)并且啟動(dòng)使用代碼如下:

using System;

using System.ServiceProcess;

using System.Runtime.InteropServices;

using System.Security.Principal;


public class FirewallController

{

    // 主方法:開(kāi)啟防火墻服務(wù)并啟用策略

    public static void EnableFirewall()

    {

        if (!IsRunAsAdmin())

        {

            Console.WriteLine("需要以管理員權(quán)限運(yùn)行!");

            return;

        }


        try

        {

            // 1. 啟動(dòng)防火墻服務(wù)

            StartFirewallService();


            // 2. 啟用防火墻策略

            SetFirewallStatus(true);

        }

        catch (Exception ex)

        {

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

        }

    }


    // 檢查管理員權(quán)限

    private static bool IsRunAsAdmin()

    {

        WindowsIdentity identity = WindowsIdentity.GetCurrent();

        WindowsPrincipal principal = new WindowsPrincipal(identity);

        return principal.IsInRole(WindowsBuiltInRole.Administrator);

    }


    // 啟動(dòng)Windows防火墻服務(wù)

    private static void StartFirewallService()

    {

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

        {

            if (sc.Status != ServiceControllerStatus.Running)

            {

                Console.WriteLine("正在啟動(dòng)防火墻服務(wù)...");

                sc.Start();

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

                Console.WriteLine("服務(wù)已啟動(dòng)");

            }

        }

    }


    // 設(shè)置防火墻啟用狀態(tài)

    private static void SetFirewallStatus(bool enable)

    {

        INetFwPolicy2 firewallPolicy = null;

        try

        {

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

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


            // 設(shè)置所有配置文件的狀態(tài)

            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

    }

}

使用說(shuō)明:

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

  2. 調(diào)用入口方法:

FirewallController.EnableFirewall();

代碼功能分解:

  1. 權(quán)限驗(yàn)證

    • IsRunAsAdmin() 方法驗(yàn)證當(dāng)前是否以管理員權(quán)限運(yùn)行

  2. 服務(wù)控制

    • 使用ServiceController啟動(dòng)"MpsSvc"服務(wù)

    • 設(shè)置30秒超時(shí)等待服務(wù)啟動(dòng)

  3. 防火墻策略控制

    • 通過(guò)COM接口INetFwPolicy2設(shè)置三個(gè)網(wǎng)絡(luò)配置文件的啟用狀態(tài)

    • 同時(shí)啟用:域網(wǎng)絡(luò)、專用網(wǎng)絡(luò)、公用網(wǎng)絡(luò)配置

  4. 錯(cuò)誤處理

    • 捕獲服務(wù)操作和COM接口異常

    • 輸出明確的錯(cuò)誤信息

注意事項(xiàng):

  1. 系統(tǒng)兼容性

    • 僅支持Windows Vista及更新版本

    • 需要.NET Framework 3.5+

  2. 依賴項(xiàng)

    • 需要防火墻服務(wù)存在且未被禁用

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

  3. 權(quán)限要求

    • 需要SeLoadDriverPrivilegeSeSecurityPrivilege權(quán)限

    • 需要UAC管理員批準(zhǔn)模式

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


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