Python實現簡易端口掃描器代碼實例
更新時間:2017年03月15日 09:55:49 作者:keepmov
本篇文章主要介紹了Python實現簡易端口掃描器的相關代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
在網上的一些資料的基礎上自己又添了些新內容,算是Python socket編程練手吧。
#coding=utf-8
import socket
import time
import sys
import struct
import threading
from threading import Thread,activeCount
results=[]
def portScanner(ip,port):
server = (ip,port)
sockfd = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
sockfd.settimeout(0.1) #設置阻塞模式下socket的超時時間
ret = sockfd.connect_ex(server) #成功返回0,失敗返回error的值。
if not ret:
sockfd.close()
results.append([ip,port])
#print '%s:%s is opened...' % (ip,port)
else:
sockfd.close()
pass
return ''
def ip2num(ip): #將ip地址轉換成數字
lp = [int(x) for x in ip.split('.')]
return lp[0] << 24 | lp[1] << 16 | lp[2] << 8 |lp[3]
def num2ip(num):
ip = ['','','','']
ip[3] = (num & 0xff)
ip[2] = (num & 0xff00) >> 8
ip[1] = (num & 0xff0000) >> 16
ip[0] = (num & 0xff000000) >> 24
return '%s.%s.%s.%s' % (ip[0],ip[1],ip[2],ip[3])
def iprange(ip1,ip2):
num1 =socket.ntohl(struct.unpack("I",socket.inet_aton(str(ip1)))[0])
num2 =socket.ntohl(struct.unpack("I",socket.inet_aton(str(ip2)))[0])
tmp = num2 - num1
if tmp < 0:
return None
else:
return num1,num2,tmp
if __name__ == '__main__':
if((len(sys.argv)!= 4)&(len(sys.argv)!= 2)): #用法說明
print 'Usage:\n\tscanner.py startip endip port'
print '\tscanner.py ip'
sys.exit()
if len(sys.argv)==4: #對某一IP段的掃描
time_start=time.time() #起始時間
startip = sys.argv[1] #起始IP
endip = sys.argv[2] #結束IP
port = int(sys.argv[3]) #端口號
res = iprange(startip,endip)
if not res:
print 'endip must be bigger than startone'
sys.exit()
elif res[2] == 0:
portScanner(startip,port)
else:
for x in xrange(int(res[2])+1): #IP地址依次遞增
startipnum = ip2num(startip)
startipnum = startipnum + x
if activeCount() <=1000:
Thread(target=portScanner,args=(num2ip(startipnum),port)).start()
print "There are %d hosts." %len(results)
results.sort()
for ip,port in results:
print "%s:%d is opened..." %(ip,port)
times=time.time()-time_start #用時
print 'use time : %s' % times
if len(sys.argv)==2:
time_start=time.time()
port=0
ip=sys.argv[1]
while(port<2000):
if activeCount() <= 40: #設置40線程掃描
Thread(target = portScanner, args = (ip, port)).start()
port=port+1
results.sort()
for ip,port in results:
print "%s:%d is opened..." %(ip,port)
times=time.time()-time_start
print 'use time : %s' % times
使用效果如下:


以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
淺談python中scipy.misc.logsumexp函數的運用場景
下面小編就為大家?guī)硪黄獪\談python中scipy.misc.logsumexp函數的運用場景。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06
Python中的“_args”和“__kwargs”用法詳解
*args 和 **kwargs 主要?于函數定義,你可以將不定數量的參數傳遞給?個函數,這篇文章主要介紹了Python中的“_args”和“__kwargs”用法,需要的朋友可以參考下2023-01-01

