#!/usr/local/bin/python
#-*- coding: UTF-8 -*-
####################################################################
##################################################
#qq:316118740
#BLOG:http://hi.baidu.com/alalmn
# Python IP
#
##################################################
import socket
import threading,time
socket.setdefaulttimeout(10) #
# IP
class socket_port(threading.Thread):
def __init__(self,cond, name):
super(socket_port, self).__init__()
self.cond = cond
self.cond.set()# Ture
self.HOST = name
def run(self):
#time.sleep(1) # Seeker
try:
PORT=21
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.connect((self.HOST,PORT))
print""
print self.HOST,u":",PORT,u" ",
sql_desc = "insert into port21(IP,TIME) VALUES('%s','%s')"%(self.HOST,time.strftime('%Y.%m.%d-%H.%M.%S'))
if mysql.mysql_insert(sql_desc): #
print u" "
else:
print u" "
mysql.mysql_S() #
#self.cond.wait()# , Event True ( timeout)。
self.cond.set()# Ture
return 1
except:
print ".",
#print self.HOST,u":",PORT,u" "
#self.cond.wait()# , Event True ( timeout)。
self.cond.set()# Ture
return 0
##
#socket_port("192.168.2.1")
#if socket_port("192.168.2.100"):
# print " "
#else:
# print " "
def ip2num(ip):
ip = [int(x) for x in ip.split('.')]
return ip[0]< <24 | ip[1]<<16 | ip[2]<<8 | ip[3]
def num2ip(num):
#time.sleep(0.05) #50ms
#time.sleep(0.1) #s
# data='%s.%s.%s.%s' % ( (num & 0xff000000) >> 24,
# (num & 0x00ff0000) >> 16,
# (num & 0x0000ff00) >> 8,
# num & 0x000000ff )
# #socket_port(data) # IP
if num>=IPend:
print u"IP "
return '%s.%s.%s.%s' % ( (num & 0xff000000) >> 24,
(num & 0x00ff0000) >> 16,
(num & 0x0000ff00) >> 8,
num & 0x000000ff )
def gen_ip(ip1,ip2): #
# ip
# global IPend
# start, IPend = [ip2num(x) for x in ip.split('-')]
global IPend
IPend=ip2
return [num2ip(num) for num in range(ip1,ip2+1) if num & 0xff]
##################################################
import sys
import os
import atexit
def close(): #
try:
print u"------------------ ------------------"
mysql.mysql_S() #
mysql.mysql_close() #
# python = sys.executable
# os.execl(python, python, * sys.argv)
# mysql.mysql_close() #
time.sleep(10)
# os.system('python txt.py')
python = sys.executable
os.execl(python, python, * sys.argv)
#########
except:
print u"------------------ --- ------------------"
sys.exit(0) #
def dqsqlite_bcini(): # +1
try:
ini.ini_get() # INI
abc=int(ini.ID)+1 # ID
sql_desc = "SELECT * FROM ip where ID='%s'"%(abc)
n = mysql.cursor.execute(sql_desc)
mysql.cursor.scroll(0)
for row in mysql.cursor.fetchall():
ini.ini_write(abc,row[1],row[2]) # INI
#
# sqlite_cursor = sqlite.sqlite_conn.cursor()
# sql_desc = "SELECT * FROM ip where ID='%s'"%(abc)
# sqlite_cursor.execute(sql_desc)
# for row in sqlite_cursor:
# ini.ini_write(abc,row[1],row[2]) # INI
# sqlite.sqlite_cursor.close() #
#return 1
atexit.register(close)#
except:
print u" !!"
#return 0
# sqlite.sqlite_S() #
# sqlite.sqlite_close() #
atexit.register(close)#
import ini
import mysql
if __name__=='__main__':
try:
mysql.mysql_open() #
ini.ini_get() # INI
print u" IP:",ini.IP1,u"-------",u" IP:",ini.IP2
if ini.IP1>=ini.IP2:
print u"IP "
dqsqlite_bcini() # +1
print u"IP "
list_ip=gen_ip(ip2num(ini.IP1),ip2num(ini.IP2))
I1 = 0 # list
print u" IP"
ip=0
while I1 < len(list_ip):
if ip>=255:
ini.ini_write(int(ini.ID),list_ip[I1],ini.IP2) # INI
ip=0
print list_ip[I1]
ip = ip + 1
#print list_ip[I1]
time.sleep(0.1) # Seeker
cond = threading.Event()
hider = socket_port(cond,list_ip[I1])
hider.start()
I1 = I1 + 1 #
print u"IP "
dqsqlite_bcini() # +1
except:
#dqsqlite_bcini() # +1
atexit.register(close)
#######################################################################