如何应用 AutoIt 修改本机的防火墙配置?(开启,关闭防火墙,添加程序信任到防火墙)
以前,公司的实施人员配置好项目之后,不同的机器之间经常性的无法建立链接,后来发现是防火墙的设置。虽然是个小问题,但是经常性的忘记这个配置。
现在,我决定把对防火墙的设置,加入到我给实施人员的配置工具中。
打开防火墙其实很简单,代码如下:
#RequireAdmin Run(@ComSpec & " /c " & 'Netsh advfirewall set currentprofile state on', "", @SW_HIDE)
该命令以管理员身份运行才能起作用,所以需要 #RequireAdmin
如果要关闭防火墙,只需要把Run里面的命令中的on换成off即可。
遇到问题当然不能关闭防火墙就了事,最好还是在防火墙开启的情况下,添加应用程序到信任列表。
这儿我就放一个简单的函数供大家参考,应该说是万变不离其宗啊
Func in_add() If FileExists(@ScriptDir & "SageTouchBrower.exe") = 1 Then Run(@ComSpec & " /c " & 'netsh advfirewall firewall delete rule name="SageTouchBrower" dir=in program="' & @ScriptDir & 'SageTouchBrower.exe"', "", @SW_HIDE) _GUICtrlListBox_AddString($hListBox, "Delete the existing in rule for progcess: SagetouchBrower.exe in fireware") Run(@ComSpec & " /c " & 'netsh advfirewall firewall add rule name="SageTouchBrower" dir=in program="' & @ScriptDir & 'SageTouchBrower.exe"' & " security=notrequired action=allow", "", @SW_HIDE) _GUICtrlListBox_AddString($hListBox, "Add a new in rule for process: SagetouchBrower.exe in fireware") Else _GUICtrlListBox_AddString($hListBox, "文件 " & @ScriptDir & "SageTouchBrower.exe 不存在!...") _GUICtrlListBox_AddString($hListBox, "所以无法把大屏端应用程序添加信任到防火墙,请手动配置!" ) EndIf EndFunc
解释一下:
要把某应用程序添加到信任列表,必须要:
1. 判断该程序是否存在;如果不存在,添加也没什么必要;
2. 删除防火墙设置中已经添加的该运行程序的信任,要不然点一次我的配置文件就添加一次信任,还不把机器整死?
3. 做的每一步操作,都有记录,当然,该记录可以输入到log文件,也可以展示出来