我想使用python(如nmap)实现操作系统检测,我找到python-nmap-0.3.4.tar.gz库,但它没有提供操作系统作为响应! 如何更改它以实现我的目标。
编辑: 在site示例中:
>>> import nmap
>>> nm = nmap.PortScanner()
>>> nm.scan('127.0.0.1', '22-443')
>>> print(nm.csv())
host;protocol;port;name;state;product;extrainfo;reason;version;conf
127.0.0.1;tcp;22;ssh;open;OpenSSH;protocol 2.0;syn-ack;5.9p1 Debian 5ubuntu1;10
127.0.0.1;tcp;25;smtp;open;Exim smtpd;;syn-ack;4.76;10
127.0.0.1;tcp;53;domain;open;dnsmasq;;syn-ack;2.59;10
127.0.0.1;tcp;80;http;open;Apache httpd;(Ubuntu);syn-ack;2.2.22;10
127.0.0.1;tcp;111;rpcbind;open;;;syn-ack;;10
127.0.0.1;tcp;139;netbios-ssn;open;Samba smbd;workgroup: WORKGROUP;syn-ack;3.X;10
127.0.0.1;tcp;443;;open;;;syn-ack;;
它找到操作系统,但是当我自己运行时它没有显示任何操作系统。 有什么功能可以找到远程操作系统吗?
答案 0 :(得分:4)
尝试使用-O选项
nm.scan('scanme.nmap.org', arguments='-O')
问题是,如果你这样做,信息就不会出现
print(nm.csv())
所以你必须做一个循环
nm.scan("127.0.0.1", arguments="-O")
if 'osclass' in nm['127.0.0.1']:
for osclass in nm['127.0.0.1']['osclass']:
print('OsClass.type : {0}'.format(osclass['type']))
print('OsClass.vendor : {0}'.format(osclass['vendor']))
print('OsClass.osfamily : {0}'.format(osclass['osfamily']))
print('OsClass.osgen : {0}'.format(osclass['osgen']))
print('OsClass.accuracy : {0}'.format(osclass['accuracy']))
print('')
PS:你需要python 3.x,我不认为它适用于Python 2.x
EDIT 当然,您可以通过
直接访问print nm['127.0.0.1']['osclass']
或
print nm['127.0.0.1']['osclass']['vendor']
答案 1 :(得分:1)
如果只需要操作系统名称,则可以执行以下操作:
import nmap
nm = nmap.PortScanner()
machine = nm.scan('<hostIP>', arguments='-O')
print(machine['scan']['<hostIP>']['osmatch'][0]['osclass'][0]['osfamily'])
这将提供操作系统名称[Ex:'Linux']