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

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

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

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

解决方法:

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

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?

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

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

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

祝好运!

相关文章

Windows2012R2备用域控搭建 前置操作 域控主域控的主dns:自...
主域控角色迁移和夺取(转载) 转载自:http://yupeizhi.blo...
Windows2012R2 NTP时间同步 Windows2012R2里没有了internet时...
Windows注册表操作基础代码 Windows下对注册表进行操作使用的...
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的...
一个简单的Windows Socket可复用框架说起网络编程,无非是建...