首頁 >後端開發 >Python教學 >如何呼叫python-nmap來實作掃描區域網路存活主機(程式碼)

如何呼叫python-nmap來實作掃描區域網路存活主機(程式碼)

不言
不言原創
2018-09-20 16:59:217512瀏覽

這篇文章帶給大家的內容是關於如何呼叫python-nmap來實現掃描區域網路存活主機(程式碼),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

使用環境:Raspberry 3b netifaces python-nmap nmap

呼叫netifaces自動取得ip位址:

##

def get_gateways():    
return netifaces.gateways()['default'][netifaces.AF_INET][0]

將ip位址產生一個網段中所有ip位址的清單:

def get_ip_lists(ip):
    ip_lists = []    
    for i in range(1, 256):
        ip_lists.append('{}{}'.format(ip[:-1], i))    
        return ip_lists

#主要實作程式碼及資料分割:

def main(ip=None):
    ip=get_gateways()
    ip_lists=get_ip_lists(ip)
    nmScan,temp_ip_lists,hosts = nmap.PortScanner(),[],ip[:-1]+'0/24'
    ret = nmScan.scan(hosts=hosts, arguments='-sP')
    print('扫描时间:'+ret['nmap']['scanstats']['timestr']+'\n命令参数:'+ret['nmap']['command_line'])
    for ip in ip_lists:
        print('ip地址:'+ip+':')
        if ip not in ret['scan']:
            temp_ip_lists.append(ip)
            print('扫描超时')
        else:print('已扫描到主机,主机名:'+ret['scan'][ip]['hostnames'][0]['name'])
    print(str(hosts) +' 网络中的存活主机:')
    for ip in temp_ip_lists:ip_lists.remove(ip)
    for ip in ip_lists:print(ip)

完整程式碼:

#!/usr/bin/python
#_*_ coding:utf8 _*_
import netifaces,nmap

def get_gateways():
    return netifaces.gateways()['default'][netifaces.AF_INET][0]

def get_ip_lists(ip):
    ip_lists = []
    for i in range(1, 256):
        ip_lists.append('{}{}'.format(ip[:-1], i))
    return ip_lists

def main(ip=None):
    ip=get_gateways()
    ip_lists=get_ip_lists(ip)
    nmScan,temp_ip_lists,hosts = nmap.PortScanner(),[],ip[:-1]+'0/24'
    ret = nmScan.scan(hosts=hosts, arguments='-sP')
    print('扫描时间:'+ret['nmap']['scanstats']['timestr']+'\n命令参数:'+ret['nmap']['command_line'])
    for ip in ip_lists:
        print('ip地址:'+ip+':')
        if ip not in ret['scan']:
            temp_ip_lists.append(ip)
            print('扫描超时')
        else:print('已扫描到主机,主机名:'+ret['scan'][ip]['hostnames'][0]['name'])
    print(str(hosts) +' 网络中的存活主机:')
    for ip in temp_ip_lists:ip_lists.remove(ip)
    for ip in ip_lists:print(ip)

if __name__ == '__main__':
    main()

#實驗截圖:

以上是如何呼叫python-nmap來實作掃描區域網路存活主機(程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn