通常在一台装有防火墙的电脑上运行程序的场合,往往会弹出对话框提示:是否允许执行该应用程序。
我们在开发软件的时候,可以事先在软件里面设置当前软件为防火墙允许通过的软件。这样,用户在使用时就可以避开前面提到的弹框了。
在c#中,我们可以加入以下代码:
INetFwMgr netFwMgr = (INetFwMgr)Activator.CreateInstance(Type.GetTypeFromProgID("HNetCfg.FwMgr"));
INetFwAuthorizedApplication app = (INetFwAuthorizedApplication)Activator.CreateInstance(
Type.GetTypeFromProgID("HNetCfg.FwAuthorizedApplication"));
app.Name = "MyProgram";
app.ProcessImageFileName = Application.ExecutablePath;
app.Enabled = true;
netFwMgr.LocalPolicy.CurrentProfile.AuthorizedApplications.Add(app);
这样,防火墙就允许指定的软件执行了。
本文介绍了如何在C#开发中通过编程方式让软件自动获得防火墙的授权,避免用户每次运行时的提示对话框,通过`INetFwMgr`和`INetFwAuthorizedApplication`类实现本地策略的修改。
992

被折叠的 条评论
为什么被折叠?



