mirror of
https://github.com/Threekiii/Awesome-POC.git
synced 2025-11-05 10:50:23 +00:00
55 lines
1.3 KiB
Markdown
55 lines
1.3 KiB
Markdown
|
|
# Discuz!X 3.4 admincp_setting.php 后台SQL注入漏洞
|
|||
|
|
|
|||
|
|
## 漏洞描述
|
|||
|
|
|
|||
|
|
不久以前Discuz!X的后台披露了一个sql注入的漏洞,这里也要感谢漏洞的发现和研究者(无糖的kn1f3)。
|
|||
|
|
|
|||
|
|
## 漏洞影响
|
|||
|
|
|
|||
|
|
```
|
|||
|
|
Discuz!X <3.4 R20191201 版本
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 环境搭建
|
|||
|
|
|
|||
|
|
将 **upload**目录下的文件拷入**phpstudy**下的WWW目录打开网站按照步骤安装就行了
|
|||
|
|
|
|||
|
|
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
## 漏洞复现
|
|||
|
|
|
|||
|
|
来到后台页面, 在 **UCenter 应用 ID** 位置的参数添加单引号并抓包
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
发现出现SQL语句报错
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
使用报错注入去获取版本号
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
这里的参数为 `settingnew[uc][appid]`
|
|||
|
|
|
|||
|
|
查看文件 **\source\admincp\admincp_setting.php**, 在2677行找到了输入点
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
根据报错语句找到SQL语句执行点,在文件**uc_client\model\base.php** 中的 206行
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
通过这里的语句可以看到我们可以使用 **union注入** 的方法来写入恶意文件(**secure_file_priv不能为Null**)
|
|||
|
|
|
|||
|
|

|
|||
|
|
|
|||
|
|
```plain
|
|||
|
|
1' union select "<?php phpinfo();?>" into outfile 'D:/test.php';--+
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
也可以使用其他的方法
|