Python 局域网扫描存活主机开放端口

'''
Python 局域网扫描存活主机开放端口 by 郑瑞国
1、ping指定IP判断主机是否存活
2、ping所有IP获取所有存活主机
3、nmap扫描存活主机开放端口
#注: 若在Linux系统下 ping -n 改为 ping -c 
     若在windows系统下 ping -n 不变
'''
import nmap
import socket
import os
import threading
import time 
 
IPList = [] 
def ping_ip(ip):                                          #1、ping指定IP判断主机是否存活
    output = os.popen('ping -n 1 %s'%ip).readlines()      #注:若在Linux系统下-n 改为 -c
    for w in output:
        if str(w).upper().find('TTL')>=0:
            IPList.append(ip)
 
def ping_net(ip):                                         #2、ping所有IP获取所有存活主机
    pre_ip = (ip.split('.')[:-1])
    for i in range(1,256):
        add = ('.'.join(pre_ip)+'.'+str(i))
        threading._start_new_thread(ping_ip,(add,))
        time.sleep(0.01)
  
def nmapScan(ip):                                         #3、nmap扫描存活主机开放端口
    nmScan = nmap.PortScanner()
    x=nmScan.scan(ip)
    for port in range(1,65536):
        try:
            state = x['scan'][ip]['tcp'][int(port)]['state']
            if state != 'unknown':
                print(ip,port,state)
        except:
            pass

if __name__ == '__main__':
    ping_net(socket.gethostbyname(socket.gethostname()))
    for ip in IPList:
        nmapScan(ip)

猜你喜欢

转载自blog.csdn.net/zheng_ruiguo/article/details/86001690