python 局域网扫描_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攻击,让目标下线

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值