Heim > Backend-Entwicklung > Python-Tutorial > So rufen Sie python-nmap auf, um das lokale Netzwerk nach Live-Hosts zu durchsuchen (Code)

So rufen Sie python-nmap auf, um das lokale Netzwerk nach Live-Hosts zu durchsuchen (Code)

不言
Freigeben: 2018-09-20 16:59:21
Original
7474 Leute haben es durchsucht

In diesem Artikel geht es darum, wie man Python-nmap aufruft, um das LAN nach überlebenden Hosts zu durchsuchen. Ich hoffe, dass es für Freunde hilfreich ist.

Nutzungsumgebung: Raspberry 3b+ +netifaces+python-nmap+nmap

Aufruf von Netifaces, um automatisch die IP-Adresse zu erhalten:

def get_gateways():    
return netifaces.gateways()['default'][netifaces.AF_INET][0]
Nach dem Login kopieren

Generieren Sie eine Liste aller IP-Adressen im Netzwerksegment aus der IP-Adresse:

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

Implementieren Sie hauptsächlich Code- und Datensegmentierung:

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)
Nach dem Login kopieren

Vollständiger Code:

#!/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()
Nach dem Login kopieren

Experiment-Screenshot:

Das obige ist der detaillierte Inhalt vonSo rufen Sie python-nmap auf, um das lokale Netzwerk nach Live-Hosts zu durchsuchen (Code). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage