码迷,mamicode.com
首页 > 数据库 > 详细

sql绕过转义符注入

时间:2019-08-07 12:09:02      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:字节   from   斜杠   使用   bsp   asc   unicode   重点   语句   

宽字节绕过总结

1、  重点:转义符反斜杠\,ASCII码0x5C

2、  在双字节字符集中, 在\前面增加高字节,0x5C被当做低字节,组合为“汉字”,导致\符号被“吃掉”,后续字符逃出限制,从而绕过转义。

3、  GB2312编码里\不会被“吃掉”。

4、  GBK,GB18030,BIG5等低字节符范围中含有0x5c的双字节字符编码集均存在宽字节注入/绕过。

5、  UTF编码方式\不会被“吃掉”

6、  程序中使用转码函数不当,也会出现宽字节注入/绕过,这时候跟页面编码无关

 

示例:

某存在SQL注入的业务场景,注入一个单引号之后,URL和SQL语句如下:

http://example.com/index.php?username=alan’

-->

Select * from tb where username=‘alan\’’

核心问题是要把反斜杠\消除,将注入字符替换为%df’,URL和SQL语句如下:

http://example.com/index.php?username=alan%df’

-->

Select * from tb where username=‘alan%df\’’

由于%df\ à     %df%5c    à     運,最终构成的SQL语句为:

Select * from tb where username=‘alan運’’

注入的%df与系统自动添加的反斜杠一起,构成了一个unicode字符集中的字符“運”,从而消除了反斜杠,使得注入的单引号闭合了前面的查询语句。

sql绕过转义符注入

标签:字节   from   斜杠   使用   bsp   asc   unicode   重点   语句   

原文地址:https://www.cnblogs.com/lwfiwo/p/11314408.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!