python包系列1

2016-05-04  本文已影响114人  磨人的小妖精九斤

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下的运行图

first two

代码如下:
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 吧

上一篇 下一篇

猜你喜欢

热点阅读