最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
Python实现简易端口扫描器代码实例
时间:2017-06-28 编辑:简简单单 来源:一聚教程网
在网上的一些资料的基础上自己又添了些新内容,算是Python socket编程练手吧。
代码如下 | 复制代码 |
#coding=utf-8 importsocket importtime importsys importstruct importthreading fromthreadingimportThread,activeCount
results=[] defportScanner(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的值。 ifnotret: sockfd.close() results.append([ip,port]) #print '%s:%s is opened...' % (ip,port) else: sockfd.close() pass return''
defip2num(ip): #将ip地址转换成数字 lp=[int(x)forxinip.split('.')] returnlp[0] <<24| lp[1] <<16| lp[2] <<8|lp[3]
defnum2ip(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])
defiprange(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 iftmp<0: returnNone else: returnnum1,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()
iflen(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) ifnotres: print'endip must be bigger than startone' sys.exit() elifres[2]==0: portScanner(startip,port) else: forxinxrange(int(res[2])+1): #IP地址依次递增 startipnum=ip2num(startip) startipnum=startipnum+x ifactiveCount() <=1000: Thread(target=portScanner,args=(num2ip(startipnum),port)).start()
print"There are %d hosts."%len(results) results.sort() forip,portinresults: print"%s:%d is opened..."%(ip,port) times=time.time()-time_start #用时 print'use time : %s'%times
iflen(sys.argv)==2: time_start=time.time() port=0 ip=sys.argv[1] while(port<2000): ifactiveCount() <=40: #设置40线程扫描 Thread(target=portScanner, args=(ip, port)).start() port=port+1 results.sort() forip,portinresults: print"%s:%d is opened..."%(ip,port) times=time.time()-time_start print'use time : %s'%times |
使用效果如下:
相关文章
- 打开UDP端口1434以浏览命名实例 01-24
- PHP导出数据超时的优化建议解读 10-31
- PHP之mysql位运算解析 10-31
- Laravel实现登录跳转功能解析 10-31
- php双向队列解读 10-31
- Laravel异常上下文解决教程 10-24