找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 1817|回复: 0
打印 上一主题 下一主题

织梦(Dedecms)V5.X 本地文件包含漏洞

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:" `, x6 V* `# K8 o
DedeCms 5.x漏洞描述:( [  \# m5 _9 D
DedeCms是免费的PHP网站内容管理系统。
- J3 O% [3 K4 R
; ?6 q4 J# U/ M: ^# ^plus/carbuyaction.php里没有对变量进行严格的过滤
8 }! k3 C% J% T7 |% M( h% Q9 s# \
出现漏洞的两个文件为:
! k) `# k' A7 w2 l6 J0 dInclude/payment/alipay.php) U+ z* n8 s1 \& l, S
Include/payment/yeepay.php5 g: W# ?  Z! s0 ]# g+ ]/ w& c
漏洞均出现在respond方法里- ^) m0 k8 S  I: a  u; J) e1 _* N3 q
8 T( c* |2 W% J5 t) A) y+ v; S
Include/payment/alipay.php + v+ E( C9 Q7 {1 i
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......0 V9 E9 V4 L7 v
                        " R+ }: _( ?2 {! h! i7 Q; ~
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。0 G4 E, j. B& L4 {7 p6 J
Include/payment/yeepay.php
( }8 M- s/ k$ ^......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......; D" e+ I0 e! B: s
                        , m) B, N3 \, A5 r% P
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
# S% p+ G) m" zhttp://bugscan.net/manage/node/83
: G& n, c1 A6 o3 R- Hhttp://www.cnseay.com/2515/
, R# L8 Y! K9 i% q8 y*>
2 ^6 b# U' ]  J$ v  U& z/ s测试方法:8 y" d4 H; u0 ?3 \# ]* r
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
( Q$ F. l0 p; q; S3 J9 V2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径2 t* C& ^( ~* d. e5 q
修复方法:
% b+ \9 p! q6 Y' p2 }/ X3 }目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
  F; g& H* a8 o: q, Ohttp://www.dedecms.com/products/dedecms/6 P% g  e; Z" j( K& }& ]1 Q

. F8 w8 d$ @& Z" Z 临时修复: 8 T/ |/ |" e! ?/ Q
1)Include/payment/alipay.php, n9 m. n4 O6 g
  大概133行左右
* K/ C) s/ n, U: |* @3 v# l8 D  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
$ X# L0 k7 \) w; _& @替换
: g) y9 u! l; x require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
: B; l: h% j# a# b& j# J2) Include/payment/yeepay.php
; \" e1 D0 R3 ?大概在145行左右  o/ }/ `' z, A2 t8 L/ M
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
1 A7 D# G5 ~; o 替换
9 m( w8 E6 g  T$ Q require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';$ [, d: g; u" E) S; Z

* e! }/ O" e' ^5 C# W, u1 J6 C
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表