我想用python(比如nmap)实现一个OS检测,我找到了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;;
它找到操作系统,但是当我自己运行时它没有显示任何操作系统。有没有找到远程操作系统的功能?
尝试使用-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.
编辑当然,您可以直接访问
print nm['127.0.0.1']['osclass']
要么
print nm['127.0.0.1']['osclass']['vendor']
如果您只需要操作系统名称,那么您可以这样做:
import nmap
nm = nmap.PortScanner()
machine = nm.scan('<hostIP>', arguments='-O')
print(machine['scan']['<hostIP>']['osmatch'][0]['osclass'][0]['osfamily'])
这将提供操作系统名称[例如:'Linux']