如何使用Python在Windows防火墙中读取和添加规则

时间:2015-10-30 10:59:35

标签: windows python-2.7 firewall windows-firewall

我正在创建一项服务,需要不断监控防火墙,以防止毫无防备的用户移除服务的大门。我的意图是使用python做到这一点。

所以,我搜索它并没有想到。

我可以使用python读取规则并将其添加到Windows防火墙吗?

1 个答案:

答案 0 :(得分:1)

以管理员身份打开Python IDLE或以管理员身份打开CMD并加载python。目的是在运行程序时,您应该具有管理员权限。

def blockrule():
 import os
 c=input('Enter Directory in the format "C:\Program Files (x86)\Common Files\"(without ""): \n')
 d=input('Enter prefix: ')
 e=input('Enter \n"1" for inbound \n"2" for outbound \n"3" for both \nWithout ""\n')
 a=[];b=[]
 for root, dirs, files in os.walk(c):
  for name in files:
   a=a+[[(os.path.join(root,name))]]
 for i in range(len(a)):
  if a[i][0][-3:]=='exe':
   b=b+a[i]
 print('Number of files: '+str(len(a))+'\nNumber of .exe files: '+str(len(b)))
 for i in range (len(b)):
  name=d+str(i)
  if e=='1':
   os.popen('netsh advfirewall firewall add rule name="'+name+'" dir=in action=block program= "'+ b[i]+'" enable=yes profile=any')
  if e=='2':
   os.popen('netsh advfirewall firewall add rule name="'+name+'" dir=out action=block program= "'+ b[i]+'" enable=yes profile=any')
  if e=='3':
   os.popen('netsh advfirewall firewall add rule name="'+name+'" dir=in action=block program= "'+ b[i]+'" enable=yes profile=any')
   os.popen('netsh advfirewall firewall add rule name="'+name+'" dir=out action=block program= "'+ b[i]+'" enable=yes profile=any')