Python 局域网主机存活扫描

#! python
# -*- coding: utf-8 -*-
__author__ = 'Deen'

import os
import threading
import argparse


# 从网关获取所有IP,如192.168.1.1-255,返回一个list存储
def get_all_ip(gateway):
    ip = list()
    # 改进,支持指定范围IP

    ip_prefix = gateway.split('.')

    # 对输入的gateway进行判断
    # 第一种输入192.168.1.1-255
    if '-' in gateway:
        parts = ip_prefix[3].split('-')
        start = int(parts[0])
        end = int(parts[1])
        prefix = ip_prefix[0] + '.' + ip_prefix[1] + '.' + ip_prefix[2] + '.'
        for i in range(start, end):
            ip.append(prefix + str(i))
    # 第二种只输入一个ip
    else:
        ip_prefix = ip_prefix[0] + '.' + ip_prefix[1] + '.' + ip_prefix[2] + '.'
        for i in range(255):
            ip.append(ip_prefix + str(i))

    # 返回一个包含所有IP的list
    return ip


def ping(ip):
    # 执行系统命令以一个管道返回
    output = os.popen('ping -n 2 %s' % ip)
    result = output.read().encode('utf-8')
    # 返回命令执行结果
    # print result
    # 根据返回结果当中是否包含关键词TTL 进行判断
    if 'TTL' in result:
        print('[-] ' + ip + '\tis up')


def main(ip):
    # 采用多线程,创建一个线程池
    threads = []
    ips = get_all_ip(ip)
    for ip in ips:
        # 加入线程
        t = threading.Thread(target=ping, args=(ip,))
        threads.append(t)
    print '[+] Scaning start'
    for i in threads:
        i.start()
    for i in threads:
        t.join()


if __name__ == '__main__':
    parser = argparse.ArgumentParser(description='This a script to scan the LAN')
    parser.add_argument('ip', default='192.168.1.1', help='Eg:  192.168.1.1 or 192.168.1.1-33')
    args = parser.parse_args()
    main(args.ip)

写得比较简单,还有还多要写

TO DO

  • 返回目标信息,像scanport一样
  • 如果是wifi,进行ddos攻击,让目标下线



  _Deen