vue项目接口域名动态的获取方法
568
2022-08-24
Python中python-nmap模块的使用(python nmea)
目录
python-nmap的安装
python-nmap模块的使用
portScanner()类
环境: python 2.7.13
Windows和Linux默认都是不安装python-nmap的,我们得手动安装
python-nmap的安装
linux:
wge t -zxvf python-nmap-0.6.1.tar.gzcd python-nmap-0.6.1python setup.py install
Windows: pip install python-nmap
python-nmap模块的使用
portScanner()类
portScanner()类用于实现对指定主机进行端口扫描
nmScan=nmap.PortScanner() #实例化
scan( host , port , args ) 方法:以指定方式扫描指定主机或网段的指定端口
参数:
host : 要扫描的主机或网段,可以是一个单独的ip:192.168.10.10 ;也可以是一个小范围网段:192.168.10.10-20 ;也可以是一个大网段:192.168.10.0/24port : 可选参数,要扫描的端口,多个端口用逗号隔开,如:20,21,22,23,24args :可选参数,要扫描的方式
import nmapnm = nmap.PortScanner()nm.scan('192.168.10.10-100', '22,21','-sV')也可以这样nm.scan(hosts='192.168.1.0/24', arguments='-n -sP -PE -PA21,23,80,3389')
command_line() 方法:返回的扫描方法映射到具体的nmap命令行,也就是我们上面执行的nm.scan()命令,对应的具体的nmap的命令
import nmapnm = nmap.PortScanner()nm.scan('192.168.10.10-100', '22,21','-sV') a=nm.command_line()print(a)###########################nmap -oX - -p 20,21 -sV 192.168.125.134
scaninfo() 方法:返回nmap扫描信息,格式为字典类型
import nmapnm = nmap.PortScanner()nm.scan('192.168.10.10-100', '22,21','-sV')a=nm.scaninfo()print(a)###########################{'tcp': {'services': '20-21', 'method': 'syn'}}
all_hosts()
import nmapnm = nmap.PortScanner()nm.scan('192.168.10.10-12', '22,21','-sV')####################################################['192.168.10.10','192.168.10.11','192.168.10.12']
查看扫描主机的详细信息: nm['192.168.125.134']
import nmapnm=nmap.PortScanner()nm.scan('192.168.125.134','445')a=nm['192.168.125.134'] #返回主机的详细信息print(a)##################################{'status': {'state': 'up', 'reason': 'arp-response'}, 'hostnames': [{'type': 'PTR', 'name': 'bogon'}], 'vendor': {'00:0C:29:F6:2B:F0': 'VMware'}, 'addresses': {'mac': '00:0C:29:F6:2B:F0', 'ipv4': '192.168.125.134'}, 'tcp': {445: {'product': 'Microsoft Windows 7 - 10 microsoft-ds', 'state': 'open', 'version': '', 'name': 'microsoft-ds', 'conf': '10', 'extrainfo': 'workgroup: WORKGROUP', 'reason': 'syn-ack', 'cpe': 'cpe:/o:microsoft:windows'}}}
查看主机扫描的端口包含的协议(TCP/UDP):nmap['192.168.125.134'].all_protocols() 返回列表型数据
import nmapnm=nmap.PortScanner()nm.scan('192.168.125.134','445')a=nm['192.168.125.134'].all_protocols() #返回主机扫描的端口包含的协议print(a)##################################['tcp']
查看扫描的端口哪些端口提供了TCP协议:nmap['192.168.125.134']['tcp']
import nmapnm=nmap.PortScanner()nm.scan('192.168.125.134','445')a=nm['192.168.125.134']['tcp'] #返回主机扫描的端口哪些端口包含了TCP协议,返回具体信息b=nm['192.168.125.134']['tcp'].keys() #只返还端口,返回列表型数据print(a)print(b)##################################{445: {'product': 'Microsoft Windows 7 - 10 microsoft-ds', 'state': 'open', 'version': '', 'name': 'microsoft-ds', 'conf': '10', 'extrainfo': 'workgroup: WORKGROUP', 'reason': 'syn-ack', 'cpe': 'cpe:/o:microsoft:windows'}}[445]
查看该端口是否提供了TCP协议:nmap['192.168.125.134'].has_tcp(445) ,返回布尔类型的数据
import nmapnm=nmap.PortScanner()nm.scan('192.168.125.134','445')a=nm['192.168.125.134'].has_tcp(445) #判断该端口是否提供TCP协议print(a)##################################True
查看该协议下端口的状态:nmap['192.168.125.134']['tcp'][445][state]
import nmapnm=nmap.PortScanner()nm.scan('192.168.125.134','445')a=nm['192.168.125.134']['tcp'][445]['state']print(a)##################################open
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~