新手学python之端口扫描系统

明天求学一下利用python操作系统财富(命令、ip),那也是当做基础部分大最终壹篇,从下一次开首将展开实战,从小项目动手已实际必要为落脚点来系统的读书运用python。 

百无聊赖写的一个微小程序,主要作用如下:

 1 #!/usr/local/bin/python2.7
 2 # -*- coding:utf-8 -*-
 3 '''
 4 Python群125240963
 5 使用python获取本机ip地址
 6 '''
 7 import socket
 8 
 9 def get_local_ip():
10     #获取本机电脑名
11     this_name = socket.getfqdn(socket.gethostname())
12     #获取本机ip
13     this_ip = socket.gethostbyname(this_name)
14     print this_name
15     print  this_ip
16 
17 get_local_ip()
18 
19 '''
20 python 执行命令
21 '''
22 import  os
23 #python 方法1:执行ls命令
24 os.system("ls")
25 
26 #方法二:
27 import commands
28 commands.getstatusoutput("ls")  

1,从自有API接口获取具备的外网IP段;

 

二,用Nmap 遍历扫描全体的IP段,-oX 生成XML的扫视报告;

三,用xml.etree.ElementTree模块方法读取XML文件,将ip,开放端口,对应服务等写入Mysql数据库

效益很简短,未有满意老大高大上的供给,所以那些小项目就那样勇敢的挂掉了!~~~完全都还没思考程序特别终止,扫描服务器万分歇菜的动静。

贴上代码:

 代码如下

#coding:utf-8
import sys,os,time,subprocess
import MySQLdb
import re,urllib2
import ConfigParser
from IPy import IP
import xml.etree.ElementTree as ET
 
nowtime = time.strftime(‘%Y-%m-%d’,time.localtime(time.time()))
configpath=r’c:portscanconfig.ini’
#盛传api接口主路线,遍历获取具有的ip列表,用IPy模块格式成1二柒.0.0.5/10四的格式
def getiplist(ipinf):
serverarea=[‘tj101′,’tj103′,’dh’,’dx’]
iplist=[]
for area in serverarea:
ipapi=urllib2.urlopen(ipinf+area).read()
for ip in ipapi.split(‘n’):
#看清如若ip列表不为空,调换来ip/网关格式,再格式化成ip/24的格式
if ip:
ip=ip.replace(‘_’,’/’)
ip=(IP(ip))
iplist.append(str(ip))
ipscan(iplist,nmapathx)
 
#传递ip地址文件和nmap路线
def ipscan(iplist,nmapath):
#古老的去重,对ip文件中的ip地址实行去重
newiplist=[]
scaniplist=[]
for ip in iplist:
if ip not in newiplist:
newiplist.append(ip)
#遍历全部ip段,批量扫描,生成xml格式报告
for ip in newiplist:
filename=nowtime+ip.split(‘/’)[0]+’.xml’
filepath=r”c:portscanscanres\”
nmapcmd=nmapath+’ -PT ‘+ip.strip(‘rn’)+’ -oX ‘+filepath+filename
os.system(nmapcmd)
scaniplist.append(ip)
writeinmysql(scaniplist)
 
#入库模块是某大婶发写好的给自己笔者只是简短修改了哈,首借使xml.etree.ElementTree模块。
def writeinmysql(scaniplist):
filepath=r”c:portscanscanres”
for ip in scaniplist:
xmlfile=filepath+’\’+ip+’.xml’
#缩进哈 发小说的时候暂且改的,懒得缩进了
root=ET.parse(xmlfile).getroot()
allhost=root.findall(‘host’)
conn=MySQLdb.connect(host=’10.5.10.57′,user=’nxadmin’,passwd=’nxadmin.com’,port=3306,db=’scandb’,charset=’utf8′)
cur= conn.cursor()
for host in allhost:
address = host.find(‘address’)
#率先剖断端口是否open的,借使是再张开入库
for port in host.find(‘ports’).findall(‘port’):
if port.find(‘state’).attrib[‘state’]==”open”:
ip=address.attrib[‘addr’]
portval=port.attrib[‘portid’]
state=port.find(‘state’).attrib[‘state’]
sql = “INSERT INTO portscan (ip,port,state) VALUES(%s,%s,%s)”
params=[ip,portval,state]
cur.execute(sql,params)
conn.commit()
cur.close()
conn.close()
if __name__==”__main__”:
#读取配置文件中要扫描的IP apiurl和nmap安装文件路线
config=ConfigParser.ConfigParser()
config.readfp(open(configpath,’rb’))
nmapathx=config.get(‘nmap’,’nmapath’)
ipinf=config.get(‘ip’,’ipinf’)
getiplist(ipinf)

布局文件c:portscanconfig.ini中至关重要是api接口主url,nmap安装路线。

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图