时间:2021-05-23
# 简单的端口扫描工具# 作者: Charles# 公众号: Charles的皮卡丘import timeimport socketimport threading# 判断是否为正确的IP地址。def isIP(ip): ip_addr = ip.split('.') if len(ip_addr) != 4: return False for ipnum in ip_addr: if not (0 <= int(ipnum) < 255): return False else: return True# 端口扫描工具class scanThread(threading.Thread): def __init__(self, ip, port_min=0, port_max=65535): # 初始化。 threading.Thread.__init__(self) self.port_max = port_max self.port_min = port_min self.ip = ip # assert isinstance(int,self.port_min) and isinstance(int,self.port_max) # 重写run def run(self): return self.__checker() # 检测 def __checker(self): for port in range(self.port_min,self.port_max): self.__connect(port) # 连接 def __connect(self,port): socket.setdefaulttimeout(1) self.sock = socket.socket() try: start_time = time.time() self.sock.connect((self.ip,port)) end_time = time.time() connect_time = int(start_time - end_time) info = 'Find --> [IP]: %s, [PORT]: %s, [Connect Time]: %d' % (self.ip, port, connect_time) print(info) self.__save(info) self.sock.close() except: # print('出错误了') self.sock.close() def __save(self,info): try: with open('results.txt', 'a') as f: f.write(info + '\n') except: print('写文件出现了问题') time.sleep(0.1)if __name__ == '__main__': # 输入IP地址。 ip = input('Input IP(example <xxx.xxx.xxx.xxx>):\n') print(isIP(ip)) while not isIP(ip): ip = input('请输入正确的IP地址:\n') # 输入最小端口、 port_min = input('需要扫描的最小端口为:') while not (0 <= int(port_min) < 65535): port_min = input('请输入正确的需要扫描的最小端口:') port_max = input('需要扫描的最大端口为(65535):') while not (0 <= int(port_min) < int(port_max) < 65535): port_min = input('请输入正确的需要扫描的最大端口(65535):') num = 8 port_max = int(port_max) port_min = int(port_min) interval = (port_max - port_min) // num for i in range(interval): scanThread(ip, i * num, (i + 1) * num).start()
以上就是python 实现端口扫描工具的详细内容,更多关于python 端口扫描工具的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了python基于socket实现端口扫描的具体代码,供大家参考,具体内容如下自学Python一段时间,写个端口扫描器练练手。有什么不足之处,
本文实例讲述了Python实现的对本地host127.0.0.1主机进行扫描端口功能。分享给大家供大家参考,具体如下:前面一篇《PythonIP端口扫描工具类》
本文主要是利用scapy包编写了一个简易扫描工具,支持ARP、ICMP、TCP、UDP发现扫描,支持TCPSYN、UDP端口扫描,如下:usage:python
我们通过python-nmap实现一个高效的端口扫描工具,与定时作业crontab及邮件告警结合,可以很好的帮助我们及时发现异常开放的高危端口。当然,该工具也可
一个简易的TCP端口扫描器,使用python3实现。需求:扫描目标网站开放哪些端口号,将所有开放的端口号输出。分析:使用socket连接,如果连接成功,认为端口