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

PortSwigger SQL注入LAB7 LAB8 LAB9

PortSwigger SQL注入LAB7 & LAB8 & LAB9

今天我把这三道LAB一起来分享,主要是因为他们之间有着特别紧密的关联,至于有那些关联就让我们来看一下吧。

LAB7描述

LAB8描述

LAB9描述

【本篇目标】
1. 理解并掌握通过UNION来确定查询的列数及数据类型
2. 通过LAB7、LAB8的知识来获取LAB9所需的用户名及密码,并完成登录

一、LAB 7

我们先来看LAB7的题目,页面上的注入点是/filter?category=...,LAB的目标是要让我们确认原查询的列数,我们这里可以直接使用ORDER BY *的递增来确认原查询返回的列数

但是我们看原题目,题目要我们返回包含空值(NULL)的额外行,来确定查询返回的列数

其实很好理解,就是在进行UNION联合查询的时候把要查询的值给换成NULL,说可能说不太清楚,但是一看就明白什么意思了

Burp Suite 抓取结果1

我们可以发现服务器返回了ERROR 500错误,这是因为我们的UNION查询语句返回的列数与原查询列数不符,所以我们可以通过添加NULL的个数直到服务器不返回ERROR 500,这样就可以确定原查询的列数了

Burp Suite 抓取结果2

就像这样一样,当我们把NULL的个数增加到3的时候,服务器返回了200 OK,所以我们可以得出原查询的列数为3列,LAB7实验目标达成。

【LAB7 Payload】

' UNION SELECT NULL,NULL,NULL FROM information_schema.tables --

二、LAB 8

先看LAB8这道题,页面上的注入点仍然是/filter?category=...,LAB的目标是要让我们发现一个可以返回文本的列,并且返回对应的随机值,这里我们需要返回的值为Wo1mBK

LAB8描述

接下来我们先来通过上一个LAB的方法来获得原查询的列数,然后再到他的基础上进行下一步操作

Burp Suite 抓取结果3

通过尝试可知原查询的列数为3,那么接下来我们只需要知道那一列的数据类型支持返回字符串即可

Burp Suite 抓取结果4

在这里我们只需要把其中的NULL改为我们所需要返回的字符串Wo1mBK来对每一个列数进行尝试即可。(注意加引号,否则非字符串类型!)

Burp Suite 抓取结果5

成功定位并返回随机字符串值,LAB8实验目标达成。

【LAB8 Payload】

' UNION SELECT NULL,'Wo1mBK',NULL FROM information_schema.tables --

三、LAB 9

最后我们来看LAB9这道题,页面上的注入点还是/filter?category=...,最后一个LAB的目标是要我们获取数据库中存储的用户名和密码,并且使用administrator账户来进行登录

这道LAB相较于上一篇的LAB5和LAB6,题目中已经告诉了我们目标用户名密码被存放在了users表的usernamepassword列中,这下倒是省去了我们遍历寻找的麻烦

3.1 确认列数

还是老样子,既然我们要用到UNION,那就必然要先来确定原查询的列数,我们可以使用以下两种办法,但是此处我选的是后者:

ORDER BY  * 
SELECT NULL,NULL,...FROM information_schema.tables 

Burp Suite抓取结果6

通过尝试,我们得出原查询的列数为2

3.2 确认列数返回的数据类型

题目中我们要返回的是用户名和密码,他们的数据类型为字符串,那么现在我们要做的就是要确定这两行是否可以返回字符串

Burp Suite抓取结果7

看来这两列并不是像之前一样都支持返回字符串数据类型的,那我们就要确定是哪一行可以返回字符串了

Burp Suite抓取结果8

通过尝试,我们可以发现只有第二列是支持返回字符串的,那现在我们就可以构建最终的Payload了

3.3 构建最终Payload

由于我们一次只能返回一个字符串,所以我们需要先返回所有用户名从而来确定我们所需要的administrator用户位于的行数

Burp Suite抓取结果9

通过查询可得,我们所需要的administrator用户位于第2行(以第一行为表头来算),那么接下来我们就可以查询他的密码了

Burp Suite抓取结果10

至此我们可得administrator用户的密码为:smevzxynefrus8eviear

现在我们去网页中尝试登录

登录结果

成功登录并显示LAB已完成。

【LAB 9 Payload】

' UNION SELECT NULL,username FROM users --
' UNION SELECT NULL,password FROM users --

四、两者的区别

通过这三个LAB我们知道可以用两个方法来获取原查询的列数,但这两个方法在触发方式、可获取的信息以及使用场景上各有侧重,具体对比如下:

对比项ORDER BYSELECT NULL (UNION)
触发方式 通过逐步增加 ORDER BY 的列索引,直到出现错误来判断列数 通过加入带有 NULL 占位的 UNION SELECT,如果列数或类型不匹配会产生错误
可得到的信息 主要用于快速确认列数 既能确认列数,又能进一步测试列的数据类型和哪列能返回字符串
风险与适用性 相对隐蔽,通常不会返回额外数据,适合快速测试列数 更灵活但更具侵入性,常用于构造有效载荷以读取数据,可能触发明显的错误或日志
推荐场景 仅需确认列数时优先使用 需要继续探测数据类型和返回具体字段时使用

所以本质上它们都是用来确定目标查询的列数,但 SELECT NULL 更适合用于后续探测列的数据类型与返回能力,而 ORDER BY 更适合快速且低侵入地确认列数。

五、总结与防御建议


总结:

  • 本篇通过LAB7、LAB8、LAB9演示了如何使用ORDER BYUNION SELECT确认列数、判断可返回字符串的列,并最终读取目标用户与密码。
  • 在渗透测试中,先用低侵入的方法确认列数,再用 UNION 确认列的数据类型,可以更稳妥地构造有效载荷。

防御建议:

  • 使用参数化查询或预处理语句,避免直接拼接用户输入到 SQL 中。
  • 对输入实行严格的白名单校验与长度限制,尽量不要把未过滤的输入用于查询构造。
  • 最小化数据库账户权限,仅授予应用运行所需的最低权限,避免使用高权限账户执行应用查询。
  • 关闭或屏蔽详细错误信息,避免把数据库错误信息直接返回给用户,以减少信息泄露。
  • 部署 WAF 与入侵检测,监控异常查询模式与频繁的错误返回,并记录审计日志以便追溯。
  • 使用 ORM 或安全库替代手写 SQL,并对第三方库保持更新,修补已知漏洞。

博客园技术分享 · 请勿用于非法测试

http://www.jsqmd.com/news/859153/

相关文章:

  • 2026年新疆旅游深度指南:疆都国旅怎么选?零购物直营旅行社避坑与品质出行完全攻略 - 优质企业观察收录
  • 别再只当画图工具了!Flowable Modeler + Task App 实战:模拟一个请假审批流程
  • MySQL复制 slave_exec_mode 参数IDEMPOTENT 说明
  • 【文档编辑】打印小册子(一张A4纸4页内容)步骤
  • Omnizart部署终极方案:Docker、Colab、本地环境全攻略
  • 三星固件下载解密终极指南:Bifrost跨平台工具完全使用手册
  • 如何高效管理中文文献:Zotero茉莉花插件完整使用指南
  • Synopsys工具filter选项:后端设计效率倍增器实战指南
  • 告别花屏!手把手教你为STM32H743的RGB屏配置LVGL显示驱动(基于CubeIDE)
  • 通过curl命令快速测试与调试大模型API连接
  • 2026年大连全屋定制工厂怎么选?源头工厂直营vs传统品牌深度对比指南 - 企业名录优选推荐
  • 告别Keil和IAR?手把手教你用STM32CubeProgrammer + ST-Link烧录调试(附常见连接失败解决方案)
  • 保姆级教程:在K8s集群上部署Triton Inference Server服务(含TensorRT加速配置)
  • CANN/torchtitan-npu SFT指令微调指南
  • BCFtools基因组变异数据处理架构深度解析与技术实现
  • SpringbootWeb【入门】+Mysql【安装】
  • 亲测:2026年爱彼售后网络升级全流程解析——客观解析新服务网络与热线变化 - 亨得利官方服务中心
  • java springboot-vue 实验报告管理系统的设计与实现
  • 2026年新疆旅游深度指南:疆都国旅高品质直营游、研学游、党建红培全方位对标 - 优质企业观察收录
  • 博德之门3脚本扩展器:如何用代码重新定义你的冒险体验?
  • MySQL错误提示mysql Statement violates GTID consistency
  • 告别nRFgo Studio!Win10/Mac下用J-Flash给nRF52832烧写蓝牙协议栈S132的保姆级教程
  • Gmail 注册新门槛:当“验证”开始要求你主动发送短信与扫描 QR 码
  • ‌智慧校园选型避坑指南:三大关键点轻松搞定
  • Steam Economy Enhancer终极指南:快速提升Steam市场交易效率的完整教程
  • CANN/asc-devkit SIMT h2exp10函数
  • WebSocket配置IIS代理
  • 5分钟掌握PCB逆向分析:OpenBoardView免费开源工具深度解析
  • 常州黄金回收选哪家靠谱?2026 年本地口碑回收品牌推荐,无任何隐形扣 - 恒顺黄金回收
  • UV-UI全栈前端框架架构解析与深度指南