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

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

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

相关推荐
RisunJan2 小时前
Linux命令-nmap(网络探测和安全审计工具)
linux·网络·安全
王的宝库2 小时前
【K8s】集群安全机制(三):准入控制
网络·安全·kubernetes
志栋智能2 小时前
超自动化巡检的核心价值:效率、质量与洞察
运维·服务器·网络·人工智能·自动化
恶猫2 小时前
自动拨号换ip软件简单实现。aardio版。
java·网络·aardio·adsl·换ip·rasphone.exe·rasdial.exe
Hello_Embed2 小时前
嵌入式上位机开发入门(二十八):JSON 与 JsonRPC 入门
网络·笔记·网络协议·tcp/ip·嵌入式
数智化精益手记局2 小时前
4m变更管理实战:拆解4m变更管理四大要素的管控功能与常见难题
大数据·数据结构·数据库·人工智能·精益工程
代码羊羊2 小时前
Rust-特征trait和特征对象
服务器·网络·rust
pele2 小时前
如何解决多线图中线条颜色不渲染(仅标记和提示框显示颜色)的问题
jvm·数据库·python
银河系的一束光2 小时前
net start mysql 服务名无效。 请键入 NET HELPMSG 2185 以获得更多的帮助
数据库·mysql