Python3多线程版TCP端口扫描器
更新时间:2019年08月31日 15:12:47 作者:刺青LOVELESS
这篇文章主要为大家详细介绍了Python3多线程版TCP端口扫描器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了Python3多线程版TCP端口扫描器的具体代码,供大家参考,具体内容如下
使用命令
python BannerDemo.py -H 192.168.200.101 -p 22,3306
代码如下
import optparse import socket from socket import * from threading import * screenLock = Semaphore(value=1) def connScan(tgtHost,tgtPort): try: connSkt = socket(AF_INET,SOCK_STREAM) connSkt.connect((tgtHost,tgtPort)) connSkt.send('ViolentPython\r\n'.encode('utf-8')) result = connSkt.recv(1024) screenLock.acquire() print("[+] %d/tcp open"%tgtPort) print("[+]"+str(result)) except Exception as e: screenLock.acquire() print(e) finally: screenLock.release() connSkt.close() def portScan(tgtHost,tgtPorts): try: tgtIp = gethostbyname(tgtHost) except: print("[-] Cannot reslove '%s' : Unknown host" % tgtHost) return try: tgtName = gethostbyaddr(tgtIp) print("\n [+] Scan Result for: " + tgtName[0]) except: print("\n [+] Scan Result for: " + tgtIp) setdefaulttimeout(1) for tgtPort in tgtPorts: print("Scanning port "+ tgtPort) t = Thread(target=connScan,args=(tgtHost,int(tgtPort))) t.start() def main(): parser = optparse.OptionParser("usage%prog -H <target host> -p <target port>") parser.add_option('-H',dest='tgtHost',type='string',help='specify target host') parser.add_option('-p',dest='tgtPort',type='string',help='specify target port[s] separated by comma') options,args = parser.parse_args() tgtHost = options.tgtHost tgtPorts = str(options.tgtPort).split(',') if(tgtHost == None or tgtPorts[0] == None): print("[-] You must specify a target host and port[s]") exit(0) portScan(tgtHost,tgtPorts) if __name__ == '__main__': main()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
使用Python中的Playwright制作测试视频的实现步骤
Playwright 是一种流行的用于测试 Web 应用程序的自动化工具,它提供了多种功能来使测试更加高效和可靠,这些功能之一是能够捕获测试运行的视频,在此博客中,田辛老师将探索如何使用 Python 中的 Playwright 制作测试视频,感兴趣的同学可以参考本文自己动手尝试2023-10-10关于keras中keras.layers.merge的用法说明
这篇文章主要介绍了关于keras中keras.layers.merge的用法说明,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-05-05Django把SQLite数据库转换为Mysql数据库的过程
之前我们默认使用的是SQLite数据库,我们开发完成之后,里面有许多数据,如果我们想转换成Mysql数据库,那我们先得把旧数据从SQLite导出,然后再导入到新的Mysql数据库里去,这篇文章主要介绍了Django如何把SQLite数据库转换为Mysql数据库,需要的朋友可以参考下2023-05-05
最新评论