在网上的一些资料的基础上自己又添了些新内容,算是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 3.6.7实现端口扫描器,包括了python 3.6.7实现端口扫描器的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python 3.6.7端口扫描器的具体代码,供大家参考,具体内容如下 环境:python 3.6.7 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍python 实现端口扫描工具,包括了python 实现端口扫描工具的使用技巧和注意事项,需要的朋友参考一下 以上就是python 实现端口扫描工具的详细内容,更多关于python 端口扫描工具的资料请关注呐喊教程其它相关文章!
本文向大家介绍python实现多线程端口扫描,包括了python实现多线程端口扫描的使用技巧和注意事项,需要的朋友参考一下 一个简易的TCP端口扫描器,使用python3实现。 需求:扫描目标网站开放哪些端口号,将所有开放的端口号输出。 分析:使用socket连接,如果连接成功,认为端口开放,如果连接失败,认为端口关闭(有可能端口开放但连接失败,这里简单认为端口不开放) 使用到的库:socket,
本文向大家介绍python端口扫描系统实现方法,包括了python端口扫描系统实现方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了python端口扫描系统实现方法。分享给大家供大家参考。具体实现方法如下: 该程序的主要功能如下: 1. 从自有API接口获取所有的外网IP段; 2. 用Nmap 遍历扫描所有的IP段,-oX 生成XML的扫描报告; 3. 用xml.etree.Elemen
本文向大家介绍python编写简单端口扫描器,包括了python编写简单端口扫描器的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python编写简单端口扫描器的具体代码,供大家参考,具体内容如下 直接放代码 此代码只支持扫描域名,要扫描IP请自己修改 运行代码 代码执行结果 因为代码过于简单,这里我就不具体解释了。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支
本文向大家介绍python基于socket函数实现端口扫描,包括了python基于socket函数实现端口扫描的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python基于socket实现端口扫描的具体代码,供大家参考,具体内容如下 自学Python一段时间,写个端口扫描器练练手。有什么不足之处,请见谅 这是基于socket函数对端口进行端口扫描 所以,首先要导入socket模块