使用C#在Windows Server上添加和删除IPSec策略有哪些选择?

时间:2009-03-31 21:52:40

标签: c# .net windows ipsec

我希望能够使用C#以编程方式在Windows Server 2003上添加或删除IP安全策略。

通常,您可以通过gpedit.msc管理单元(在Windows设置 - >本地策略 - >本地计算机上的IP安全策略下)手动操作这些策略。但我需要能够通过代码添加IP过滤策略。

关于如何做到这一点的任何想法?

2 个答案:

答案 0 :(得分:3)

我已经处理了这个问题大约两个星期了,不幸的是,根据您需要的控制深度,您有两种选择:

1)使用WMI直接操作。与直觉相反,这实际上暴露了LESS控制而不是选项#2(这就是我自己做的)。这一切都是通过Win32_NetworkAdapterConfiguration类完成的。这是我对此问题的一个链接,在我研究之后的一段时间后我对它做了回应:

Methods of programatically altering ipsec rules with C#?

这会暴露较少的功能,因为您只能通过IPsec为适配器控制三件事:TCP端口,UDP端口,IP协议。 (您无法处理多个策略,不同的子网掩码等。)

2)包装netsh ipsec来做你所有的肮脏工作。这是可行的方法,因为powershell(可以通过System.Management.Automation中的PowerShell类调用)当前缺少用于执行IPSec更改的cmdlet。

Is there a cmdlet in PowerShell 2 to handle ipsec changes?

包装netsh ipsec通过System.Management.Automation.PowerShell调用的powershell管道就是我最终要做的事情。

使用System.Diagnostics.Process生成和控制shell,或使用上面提到的PowerShell类。要么应该完成工作。

<强> 如果您在某个时候切换到2008,请注意不推荐使用netsh ipsec,并确保使用netsh advfirewall。

祝你好运!

答案 1 :(得分:-2)

您可以使用System.Diagnostics.Process并使用ipsec命令作为参数运行“cmd.exe”。

您可以尝试的其他资源是Microsoft's websiteGoogle