news 2026/6/15 18:55:50

dvwa靶场暴力破解通关学习

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
dvwa靶场暴力破解通关学习
这里使用的工具是burp抓包工具

LOW

一、直接抓包发送到intruder模块进行操作

  1. 发现请i去方式是GET形式,数据有usernamepassword
  2. 那将usernamepassword添加变量,使用cluster bomb模式攻击即可,右侧添加爆破的值

  • 发送攻击后通过长度判断出用户名和密码

  • 这里我自己尝试探测是否存在sql注入,使用sqlmap工具可测试username字段(注意:携带cookie

二、代码审计

  1. 后端对与用户输入的内容未作任何过滤,直接向数据库中查询数据
  2. 这里可以得出存在字符型sql注入漏洞
总结:后端未作任何处理,存在暴力破解登录和sql注入漏洞的问题

Medium

一、抓包查看无任何变化
  • 直接将usernamepassword字段添加变量,设置攻击类型为cluster bomb模式

  • 成功得到用户名和密码(这里破解时感觉比较慢,推测后端对登录失败有延迟响应处理)
二、代码审计

  1. 使用了mysqli_real_escape_string()函数对用户输入的内容做了转义,但这是暴力破解密码,不起任何作用
  2. 将密码进行md5加密,防止了传输中密码泄露,但是md5加密存在漏洞
  3. 这里当用户登录失败后会有延迟响应,这就是在破解时感觉比较慢的原因
总结:后端进行了转义,但这种只对sql注入有影响,对暴力破解无任何影响,对密码和登录失败做了处理

High

一、抓包查看情况

  1. 这里可以看到存在user_token值(即token),其他都没有变化
  2. 这里可以考虑token值有哪些属性(一次性,随机性)
  3. 那这里就爆破密码,在passworduser_token字段添加变量,cluster bomb模式

二、payload设置
  1. password设置不变
  2. 重点是token值的选择,想到token在服务器发送的响应文件中,那就通过正则表达是提取添加

  1. 在设置中找到检索-提取选项,点击添加通过burp中自带的查找模块查找

  2. 在弹出框中输入token后选中vlue后的值(复制后续使用),就能找获取正则表达式了

  3. 在将重定向跳转改为总是

  4. 将payload类型选为递归提取,添加初始值,请求次数设置为1后就可以攻击了

三、代码审计

  1. 重点是做了对token的校验,判断是否合法
  2. 使用了mysqli_real_escape_string()函数对用户输入的内容做了转义,但这是暴力破解密码,不起任何作用
  3. 使用sleep()函数对登录失败进行了随机延迟响应
总结:添加了token值,增加了暴力破解的难度,但还是存在漏洞

Impossible

代码审计
// 这一关的代码比较多,这里列举重点的部分1.token的校验if(isset($_POST['Login'])&&isset($_POST['username'])&&isset($_POST['password'])){checkToken($_REQUEST['user_token'],$_SESSION['session_token'],'index.php');2.账号锁定// Default values$total_failed_login=3;// 最大失败登录次数:3次$lockout_time=15;// 锁定时间:15分钟$account_locked=false;// 账号锁定标记// 查数据库:获取用户失败登录次数、最后登录时间$data=$db->prepare('SELECT failed_login, last_login FROM users WHERE user = (:user) LIMIT 1;');$data->bindParam(':user',$user,PDO::PARAM_STR);$data->execute();$row=$data->fetch();// 检查账号是否因多次失败被锁定if(($data->rowCount()==1)&&($row['failed_login']>=$total_failed_login)){$last_login=strtotime($row['last_login']);// 最后失败登录时间(时间戳)$timeout=$last_login+($lockout_time*60);// 解锁时间 = 最后失败时间 + 15分钟$timenow=time();// 当前时间戳// 未到解锁时间 → 标记账号锁定if($timenow<$timeout){$account_locked=true;}}
  • PDO预编译
// 验证账号密码(PDO 预编译)$data=$db->prepare('SELECT * FROM users WHERE user = (:user) AND password = (:password) LIMIT 1;');$data->bindParam(':user',$user,PDO::PARAM_STR);$data->bindParam(':password',$pass,PDO::PARAM_STR);$data->execute();$row=$data->fetch();
  1. 这一关使用了token的防护+PDO防注入+账号锁定+随机延迟+模糊的提示
  2. 通关token增加了暴力破解的难度
  3. PDO预编译进一步杜绝了的sql注入的漏洞问题
  4. 账号锁定彻底阻断暴力破解问题
  5. 模糊的提示防止了账号的枚举问题
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:52:09

IDEA插件版摸鱼看书神器:3种方式在开发环境中高效阅读

IDEA插件版摸鱼看书神器&#xff1a;3种方式在开发环境中高效阅读 【免费下载链接】thief-book-idea IDEA插件版上班摸鱼看书神器 项目地址: https://gitcode.com/gh_mirrors/th/thief-book-idea 在紧张的编码工作间隙&#xff0c;如何在不离开开发环境的情况下享受阅读…

作者头像 李华
网站建设 2026/6/15 11:41:05

5分钟掌握Boss直聘自动化投简历:彻底告别手动求职时代

5分钟掌握Boss直聘自动化投简历&#xff1a;彻底告别手动求职时代 【免费下载链接】boss_batch_push Boss直聘批量投简历&#xff0c;解放双手 项目地址: https://gitcode.com/gh_mirrors/bo/boss_batch_push 还在为每天重复点击"立即沟通"而消耗宝贵时间吗&a…

作者头像 李华
网站建设 2026/6/15 12:45:46

Visual C++运行库一键部署终极方案:告别手动安装的烦恼

Visual C运行库一键部署终极方案&#xff1a;告别手动安装的烦恼 【免费下载链接】vcredist Lifecycle management for the Microsoft Visual C Redistributables 项目地址: https://gitcode.com/gh_mirrors/vcr/vcredist 你是否曾经因为"缺少vcruntime140.dll&quo…

作者头像 李华
网站建设 2026/6/15 15:59:16

ncmdump终极指南:快速解锁网易云NCM音乐格式的完整方案

还在为网易云音乐下载的NCM文件无法在其他播放器上播放而烦恼吗&#xff1f;想要轻松实现音乐格式的自由转换吗&#xff1f;今天我将为你介绍一款简单易用的NCM格式转换工具&#xff0c;让你的音乐收藏真正实现跨平台播放。 【免费下载链接】ncmdump 项目地址: https://gitc…

作者头像 李华
网站建设 2026/6/15 12:45:29

QQ空间青春记忆完整备份终极指南:GetQzonehistory一键导出神器

在数字时代&#xff0c;QQ空间承载了我们太多珍贵的青春记忆。那些年发过的每一条说说、每一张照片、每一次互动&#xff0c;都是无法复制的宝贵时光。GetQzonehistory作为一款开源的数据备份工具&#xff0c;能够帮你完整保存这些珍贵的数字资料&#xff0c;让青春记忆永不褪色…

作者头像 李华
网站建设 2026/6/15 12:44:37

Visual C++运行库智能管理:告别版本冲突与安装失败的终极方案

Visual C运行库智能管理&#xff1a;告别版本冲突与安装失败的终极方案 【免费下载链接】vcredist Lifecycle management for the Microsoft Visual C Redistributables 项目地址: https://gitcode.com/gh_mirrors/vcr/vcredist 在Windows系统运维和软件部署过程中&…

作者头像 李华