端口扫描工具python-nmap的使用

学习了nmap工具发现真的很强大啊,但是如果要在shell script里面想要输出自己想要的格式会很蛋疼啊,那么Python-nmap就显示出了价值。

当然python-nmap没有nmap那么强大的功能,只提供了端口扫描。

现在用一个示例简单讲一下python-nmap的使用方法:

>>> import nmap  
>>> nm = nmap.PortScanner()  
>>> nm.scan('115.239.210.26', '20-443')  
{'nmap': {'scanstats': {'uphosts': u'1', 'timestr': u'Mon Jul 29 18:52:34 2013', 'downhosts': u'0', 'totalhosts': u'1', 'elapsed': u'14.88'}, 'scaninfo': {u'tcp': {'services': u'20-443', 'method': u'syn'}}, 'command_line': u'nmap -oX - -p 20-443 -sV 115.239.210.26'}, 'scan': {u'115.239.210.26': {'status': {'state': u'up', 'reason': u'echo-reply'}, 'hostname': '', u'tcp': {80: {'state': u'open', 'reason': u'syn-ack', 'name': u'http'}}}}}  

创建PortScanner实例,然后扫描159.239.210.26这个IP的20-443端口。

>>> nm.scaninfo()  
{u'tcp': {'services': u'20-443', 'method': u'syn'}}  
>>> nm.command_line()  
u'nmap -oX - -p 20-443 -sV 115.239.210.26'  

打印简单信息

>>> nm.all_hosts()  
[u'115.239.210.26']  

查看有多少个host

>>> nm['115.239.210.26']  
{'status': {'state': u'up', 'reason': u'echo-reply'}, 'hostname': '', u'tcp': {80: {'state': u'open', 'reason': u'syn-ack', 'name': u'http'}}}  

查看该host的详细信息

>>> nm['115.239.210.26'].all_protocols()  
[u'tcp']  

查看该host包含的所有协议

>>> nm['115.239.210.26']['tcp']           
{80: {'state': u'open', 'reason': u'syn-ack', 'name': u'http'}}  
>>> nm['115.239.210.26']['tcp'].keys()  
[80]  

查看该host的哪些端口提供了tcp协议

>>> nm['115.239.210.26']['tcp'][80]     
{'state': u'open', 'reason': u'syn-ack', 'name': u'http'}  
>>> nm['115.239.210.26']['tcp'][80]['state']  
u'open'  

查看80端口的详细信息

>>> nm['115.239.210.26'].has_tcp(21)          
False  
>>> nm['115.239.210.26'].has_tcp(80)  
True  

查看该端口是否提供了tcp协议

>>> nm.scan(hosts='192.168.1.0/24', arguments='-n -sP -PE -PA21,23,80,3389')  

还可以像这样设置nmap执行的参数

以上只是一些常用的比较简单的功能,如果需要更复杂的功能,请点击python-nmap官网

支持多线程快速扫描 支持网段扫描: ScanPort.py 支持自定义网段扫描: ScanPort.py 192.168.2 支持自定义子网段扫描: ScanPort.py 192.168.3.100 192.168.3.120 支持Web端口自动显示链接: C:\>ScanPort.py Scanning [192.168.200.1]-[192.168.200.254] Total 254 ip(s)... 192.168.200.1 80 web http://192.168.200.1 192.168.200.81 80 web http://192.168.200.81 192.168.200.81 443 web https://192.168.200.81 192.168.200.99 80 web http://192.168.200.99 192.168.200.99 443 web https://192.168.200.99 192.168.200.115 80 web http://192.168.200.115 192.168.200.115 443 web https://192.168.200.115 192.168.200.123 80 web http://192.168.200.123 192.168.200.123 443 web https://192.168.200.123 192.168.200.130 80 web http://192.168.200.130 192.168.200.130 443 web https://192.168.200.130 192.168.200.133 80 web http://192.168.200.133 192.168.200.133 443 web https://192.168.200.133 192.168.200.144 80 web http://192.168.200.144 192.168.200.144 443 web https://192.168.200.144 192.168.200.151 8080 web http://192.168.200.151 192.168.200.160 443 web https://192.168.200.160 192.168.200.160 80 web http://192.168.200.160 192.168.200.163 80 web http://192.168.200.163 192.168.200.163 443 web https://192.168.200.163 192.168.200.163 1080 Proxy 192.168.200.168 80 web http://192.168.200.168 192.168.200.168 443 web https://192.168.200.168 192.168.200.168 1080 Proxy 192.168.200.173 8080 web http://192.168.200.173 192.168.200.173 443 web https://192.168.200.173 192.168.200.181 80 web http://192.168.200.181 192.168.200.181 443 web https://192.168.200.181 192.168.200.180 80 web http://192.168.200.180 192.168.200.180 443 web https://192.168.200.180 192.168.200.192 80 web http://192.168.200.192 192.168.200.192 443 web https://192.168.200.192 All RUN TIME : 97.0510001183s
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值