python局域网alive ip侦听


作者:vpoet

mails:vpoet_sir@163.com

注:写着玩,欢迎copy

 # -*- coding: cp936 -*-
# coding = utf-8 import os
import re
import thread
import time
import socket
import sys def Ping_Ip(Curr_Ip): global Count_Thread,lock,ThreadsNum #print "*****************Chile_Thread-Begin****************"+"\n" ping_cmd = "ping" +" "+Curr_Ip Ping_Answer = os.popen(ping_cmd).readlines()
patt = r'TTL=([0-9]{2})'
TTL_Str=re.findall(patt,Ping_Answer[2]) if len(TTL_Str) == 0:
#print Curr_Ip+"is Not Alive"
pass
#print "*****************Chile_Thread-Over****************"+"\n"
else:
HostInfo = socket.gethostbyaddr(Curr_Ip)
Mac_address=Get_Mac_Addr(Curr_Ip)
#print "Mac_address"+Mac_address
print "\n"+"Alive Host-----> "+"HostComputerName:"+HostInfo[0]+" Mac_address:"+Mac_address+"\t"+"Ip:"+Curr_Ip #print "*****************Chile_Thread-Over****************"+"\n" lock.acquire()
Count_Thread = Count_Thread+1
if Count_Thread ==ThreadsNum:
print "*****************NetWork_End***************"
lock.release() def Get_Mac_Addr(Curr_Ip): Mac_cmd = "nbtstat -A "+Curr_Ip
Mac_Info = os.popen(Mac_cmd).readlines() Mac_Info_Sum="" for index in range(0,len(Mac_Info)):
Mac_Info_Sum=Mac_Info_Sum+Mac_Info[index] patt_mac = r'= (.{2}-.{2}-.{2}-.{2}-.{2}-.{2})'
mac_addr= re.findall(patt_mac,Mac_Info_Sum)
return mac_addr[0] def GetAliveIp(Net_iP_Init,IpBegin,IpEnd):
SplitIp = Net_iP_Init.split(".")
Ip1=SplitIp[0]
Ip2=SplitIp[1]
Ip3=SplitIp[2] Prefix_Ip = Ip1+"."+Ip2+"."+Ip3+"." for Ip_Last in range(IpBegin,IpEnd+1):
Curr_Ip=Prefix_Ip+str(Ip_Last) thread.start_new_thread(Ping_Ip, (Curr_Ip,))
time.sleep(2) def GetNetGate():
Netgate_cmd = "ipconfig /all"
Netgate_info = os.popen(Netgate_cmd).readlines() Netgate_info_Str = ""
for index in range(0,len(Netgate_info)):
Netgate_info_Str=Netgate_info_Str+Netgate_info[index]
#print Netgate_info_Str
#print type(Netgate_info_Str) patt_hn = r'主机名 . . . . . . . . . . . . . : (.+)'
Host_Name_Local = re.findall(patt_hn,Netgate_info_Str) Rent_Ip_Begin=r'获得租约的时间 . . . . . . . . . : (.+)'
Rent_Ip_Begins=re.findall(Rent_Ip_Begin,Netgate_info_Str) Rent_Ip_End=r'租约过期的时间 . . . . . . . . . : (.+)'
Rent_Ip_Ends=re.findall(Rent_Ip_End,Netgate_info_Str) patt_ipv6 = r'本地链接 IPv6 地址. . . . . . . . : ([a-z0-9]{3,4}::[a-z0-9]{3,4}:[a-z0-9]{3,4}:[a-z0-9]{3,4}:[a-z0-9]{3,4}%[0-9]{2})'
ipv6 = re.findall(patt_ipv6,Netgate_info_Str) patt_ipv4 = r'IPv4 地址 . . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
ipv4 = re.findall(patt_ipv4,Netgate_info_Str) YanMas= r'子网掩码 . . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
YM = re.findall(YanMas,Netgate_info_Str) Netgates = r'默认网关. . . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
Ng = re.findall(Netgates,Netgate_info_Str) Patt_dhcp = r'DHCP 已启用 . . . . . . . . . . . : (.{1,2})'
dhcp_Is=re.findall(Patt_dhcp,Netgate_info_Str) Patt_dhcp_server = r'DHCP 服务器 . . . . . . . . . . . : ([0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3})'
dhcp_server = re.findall(Patt_dhcp_server,Netgate_info_Str) print "本地主机名: "+Host_Name_Local[0]
print "本机IPv6地址: "+ipv6[0]
print "本机IPv4地址: "+ipv4[0]
print "子网掩码: "+YM[0]
print "默认网关: "+Ng[0]
print "是否启用DHCP: "+dhcp_Is[0]
print "DHCP服务器IP: "+dhcp_server[0]
print "动态租约起始时间: "+Rent_Ip_Begins[0]
print "动态租约过期时间: "+Rent_Ip_Ends[0] return Ng[0] if __name__ == "__main__": Count_Thread = 0
lock = thread.allocate_lock()
print "*****************NetWork_Begin**************" Net_iP_Init=GetNetGate() IpBegin = raw_input("请输入侦听起始IP:")
IpEnd = raw_input("请输入侦听结束IP:") IntIpBegin = int(IpBegin)
IntIpEnd = int(IpEnd) ThreadsNum = IntIpEnd+1-IntIpBegin GetAliveIp(Net_iP_Init,IntIpBegin,IntIpEnd)

运行截图:


python局域网alive ip侦听的更多相关文章

  1. SQL Server使用侦听器IP访问时遇到"The target principal name is incorrect. Cannot generate SSPI context"

    在测试SQL Server 2016 Always On时,在创建侦听器后,在客户端使用SSMS, 可以用侦听器名称访问Always On集群,但是使用侦听器IP访问时遇到"The targ ...

  2. WCF:没有终结点在侦听可以接受消息的*这通常是由于不正确的地址或者 SOAP操作导致的。

    没有终结点在侦听可以接受消息的 http://xx.com/WebService.svc. 这通常是由于不正确的地址或者 SOAP 操作导致的.如果存在此情况,请参见 InnerException 以 ...

  3. GSM短信侦听的便宜方案

    侦听GSM短信常用的是OsmocomBB + C118方案,主要是用luca/gsmmap分支.使用ccch_scan这个程序可以把通信封装成GSMTAP发给本机,然后用WireShark接收GSMT ...

  4. Socket基础之-启动异步服务侦听

    Socket网络编程第一篇: 本文主要是以代码为主. .NET技术交流群 199281001 .欢迎加入 1 //负责监听的套接字 private Socket socketServer; //通知一 ...

  5. 如何将数据库引擎配置为侦听多个 TCP 端口

    SQL Server 2005         为 SQL Server 启用 TCP/IP 后,数据库引擎将侦听连接点上是否有传入的连接(由 IP 地址和 TCP 端口号组成).下列步骤将创建一个表 ...

  6. [vue]计算和侦听属性(computed&watch)

    先看一下计算属性 vue只有data区的数据才具备响应式的功能. 计算和侦听属性 - v-text里可以写一些逻辑 <div id="example"> {{ mess ...

  7. Mysql不改默认侦听回环地址而ssh通道连接的办法

    Mysql不改默认侦听回环地址而ssh通道连接的办法 文:铁乐与猫 比较新版的mysql默认侦听的网卡地址是本地回环地址:127.0.0.1: 比如你在/etc/mysql/my.cnf配置文件中往往 ...

  8. 异形Modbus客户端 和 异形modbus服务器之间的通讯 侦听模式的modbus-tcp客户端通讯

    前言 本文将使用一个Github公开的组件技术来实现一个异形ModBus TCP的客户端,方便的对异形Modbus tcp的服务器进行读写,这个服务器可以是电脑端C#设计的,也可以是特殊设备实现的,也 ...

  9. 用VLC读取摄像头产生RTSP流,DSS侦听并转发(二)

    用VLC读取摄像头产生RTSP流,DSS侦听并转发(二) 之前介绍过<用VLC读取摄像头产生RTSP流,DSS主动取流转发(一)>本文介绍另一种方法. 摄像机地址是192.1.101.51 ...

随机推荐

  1. Hdu1401-Solitaire(双向bfs)

    Solitaire is a game played on a chessboard 8x8. The rows and columns of the chessboard are numbered ...

  2. Android应用开发学习之状态栏通知

    作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz 状态栏通知涉及到两个类,一是Notification,它代表一个通知:另一个是NotificationManager ...

  3. Android使用bindService启动服务

    1.Service package com.example.ebobo; import java.util.Timer; import java.util.TimerTask; import andr ...

  4. Linux网络编程--多播

    一.多播介绍 什么是多播? 单播用于两个主机之间的端对端通信,广播用于一个主机对整个局域网上所有主机上的数据通信.单播和广播是两个极端,要么对一个主机进行通信,要么对整个局域网上的主机进行通信.实际情 ...

  5. Prototypes analyze(二叉排序树,不同树形个数)

    Prototypes analyze 时间限制:1000 ms  |  内存限制:65535 KB 难度:2   描述 ALpha Ceiling Manufacturers (ACM) is ana ...

  6. TCP三次握手的过程

    三次握手 下图就是wireshark抓包工具抓获的TCP连接建立的三次握手过程: http://www.cnblogs.com/hnrainll/archive/2011/10/14/2212415. ...

  7. 5. openCV中常用函数学习

    一.前言 经过两个星期的努力,一边学习,一边写代码,初步完成了毕业论文系统的界面和一些基本功能,主要包括:1 数据的读写和显示,及相关的基本操作(放大.缩小和移动):2 样本数据的选择:3 数据归一化 ...

  8. JQuery hover(over,out) 使用笔记

    转载自:http://www.douban.com/note/202404884/ JQuery hover(over,out) 使用笔记 JavaScript 下.onmouseover() 和 o ...

  9. sql server 删除所有表和存储过程

    1.删除外键约束 DECLARE c1 cursor for select 'alter table ['+ object_name(parent_obj) + '] drop constraint ...

  10. 【转】Visual Studio 2010在数据库生成随机测数据

    测试在项目中是很重要的一个环节,在Visual Studio 2010中,在测试方面已经有很好的支持了,比如有单元测试,负载测试等等.在数据测试的方面,Visual Studio 2010,还支持对数 ...