python中的远程OS检测

时间:2014-11-26 20:10:40

标签: python-3.x nmap os-detection

我想使用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;;

它找到操作系统,但是当我自己运行时它没有显示任何操作系统。 有什么功能可以找到远程操作系统吗?

2 个答案:

答案 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('')

更多信息https://bitbucket.org/xael/python-nmap/src/391178ab25a20d7b5edbca51e187f93dc1c16ad2/example.py?at=default&fileviewer=file-view-default

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']