当前位置: 首页 > news >正文

SQLI LABS | Less-45 POST-Error Based-String-Stacked-Bilnd

关注这个靶场的其它相关笔记:SQLI LABS —— 靶场笔记合集-CSDN博客

0x01:过关流程

输入下面的链接进入靶场(如果你的地址和我不一样,按照你本地的环境来):

 http://localhost/sqli-labs/Less-45/

本关是堆叠注入,还是一个登录框,如果你点击 “New User Click Here?” 它会让你黑进去:

黑就黑吧,本关注入点在 Password,如果你输入 1') or 1=('1,就会发现,成功伪造用户登录了:

那么我们修改一下 Payload,就可以使用堆叠注入篡改任意用户的密码 or 账户啦:

 -- 修改 id = 1 的用户账号为 HACKER1') or 1=1;update users set username='HACKER' where id=1;#

如上,我们已经能够随意篡改用户信息了。至此,SQLI LABS Less-45 POST-Error Based-String-Stacked-Bilnd 成功过关。

0x02:源码分析

下面是 SQLI LABS Less-45 POST-Error Based-String-Stacked-Bilnd 后端的部分源码,以及笔者做的笔记:

<?PHP​session_start();//including the Mysql connect parameters.include("../sql-connections/db-creds.inc");​function sqllogin($host, $dbuser, $dbpass, $dbname){// connectivity//mysql connections for stacked query examples.$con1 = mysqli_connect($host, $dbuser, $dbpass, $dbname);// 接收 username 并对其进行了过滤$username = mysqli_real_escape_string($con1, $_POST["login_user"]);// 接收 password 但未对其进行过滤$password = $_POST["login_password"];​// Check connectionif (mysqli_connect_errno($con1)) {echo "Failed to connect to MySQL: " . mysqli_connect_error();} else {@mysqli_select_db($con1, $dbname) or die("Unable to connect to the database ######: ");}​/* execute multi query */// 直接拼接进 SQL 模板中,由于 pasword 未过滤,所以导致存在漏洞,如果它在接收 password 时对其进行了 md5 加密,其实这里就不存在漏洞了$sql = "SELECT * FROM users WHERE username=('$username') and password=('$password')";// 下面是堆叠注入所依赖的函数,能够执行多条 SQL 语句。if (@mysqli_multi_query($con1, $sql)) {/* store first result set */if ($result = @mysqli_store_result($con1)) {if ($row = @mysqli_fetch_row($result)) {if ($row[1]) {return $row[1];} else {return 0;}}}}}​$login = sqllogin($host, $dbuser, $dbpass, $dbname);if (!$login == 0) {$_SESSION["username"] = $login;setcookie("Auth", 1, time() + 3600);  /* expire in 15 Minutes */header('Location: logged-in.php');} else {?>

http://www.mrgr.cn/news/74663.html

相关文章:

  • [cg] UE5 调试技巧
  • 一步到位Python Django部署,浅谈Python Django框架
  • vue.js辅助函数-mapMutations
  • RabbitMQ的工作模式
  • HTML和CSS相关的问题,为什么页面加载速度慢?
  • Java中的Push方法:实现与应用探讨
  • Python防检测之鼠标移动轨迹算法
  • 英语中常用的两者及以上的词表示,并且比较它们
  • Bootstrap 5 轮播
  • Rust 数据类型
  • 鸿蒙北向开发环境安装指南
  • 后台管理系统的通用权限解决方案(十四)基于JWT实现登录功能
  • 电路板维修入门之集成电路的检测方法篇
  • 苹果低价版Vision Pro 推迟至2027年发布:XR领域的变局与挑战
  • 【Oracle篇】掌握SQL Tuning Advisor优化工具:从工具使用到SQL优化的全方位指南(第六篇,总共七篇)
  • 开发指南079-数据冗余
  • Java 中的字符输入流详解
  • Vue3 常见的 9 种组件通信机制
  • SpringBoot开发——整合OpenCSV 实现数据导入导出-CSV
  • 《.addClass()》
  • 【Hive】【HiveQL】【大数据技术基础】 作业三 数据仓库Hive的使用
  • 107、Python并发编程:失败自动重试,一次搞懂简单实用的Timer
  • 网络安全开发详解与python实现
  • 69页可编辑PPT | 大数据基础知识培训课件
  • 系统架构设计师论文
  • 对于目标文件太大无法拉入u盘事件的解决方法