python包之python-nmap
首先需要安装上nmap,brew install nmap
pip安装python-nmap包
python3 -m pip install python-nmap
这里说明下 mac的使用环境 使用python3.5 python-nmap的包最新是0.6.0 原想使用python2的 但是包很多之前的版本都是支持3的 先这样吧。。
python-nmap
0.6.0里有两个类,这里使用PortScanner()类,实现nmap工具的端口功能封装。
看这里看这里,两张在ipython notebook python3下的运行图
代码如下:
nmapScan.py
#!/usr/bin/python
#coding:utf-8
import sys
import nmap
scan_row = []
input_date = input('please input hosts and ports:')
scan_row = input_date.split(' ')
if len(scan_row)!=2:
print('input errors,example "192.168.0.0/24 22,88"')
sys.exit(0)
hosts = scan_row[0] #接受用户输入的主机
port = scan_row[1] #接受用户输入的端口
try :
nm = nmap.PortScanner() #创建端口扫描对象
except nmap.PortScannerError :
print('nmap not found',sys.exc_info()[0]) #!!
sys.exit()
except :
print('unexpected error:',sys.exc_info()[0])
sys.exit()
try:
#调用扫描方法,参数指定扫描主机hosts,nmap扫描命令行参数arguments
nm.scan(hosts=hosts,arguments=' -v -sS -p '+port)
except Exception as e:
print('scan error:'+str(e))
for host in nm.all_hosts(): #遍历扫描主机
print('----------------------------------------------')
print('Host : %s (%s)' % (host,nm[host].hostname())) #输出主机及主机名
print('State : %s' % nm[host].state()) #输出主机状态信息,如up,down
for proto in nm[host].all_protocols(): #遍历扫协议,如tcp,udp
print('---------------------------')
print('Protocol : %s' %proto) #输入协议名
lport = nm[host][proto].keys() #获取协议的所有扫描端口,输出为字典形式
sorted(lport) #端口列表排序
for port in lport: #遍历端口及输出端口与状态
print('port : %s \tstate : %s' % (port,nm[host][proto][port]['state']))
运行方式
python3 nmapScan.py
输入主机和端口 127.0.0.1 22,80
或者像这样 192.168.0.1/24 22,443
主机结果较为简单 后一个就比较长了 try it 吧