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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
漏洞版本:
& ]2 J3 f' J5 z/ qDedeCms 5.x漏洞描述:
7 `+ e4 Z( _; J- N) N3 r6 Y. [DedeCms是免费的PHP网站内容管理系统。
% E% c8 Y6 k2 ~  X: S1 N" u- j% r7 _7 z$ p; |$ X8 [! x
plus/carbuyaction.php里没有对变量进行严格的过滤
. u, {% d1 G3 O" z% W. C! z, G6 t1 ]
出现漏洞的两个文件为:! ~7 l; d# D# a2 \
Include/payment/alipay.php
) h+ ^0 k+ p4 EInclude/payment/yeepay.php1 h  v+ Z- v, t: I# _
漏洞均出现在respond方法里' r; o9 x" |. W3 p& Z
& i! d. W6 V& F& B
Include/payment/alipay.php / v( Y4 R$ P" A5 e% y1 e
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......, ]7 ?+ i. T1 A, d0 B# k" N
                        # [$ _. ]6 I( X; |5 F( h% B! d
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
6 U) v! y1 F+ P, t5 J% [' yInclude/payment/yeepay.php% d- k7 t: n0 W' L
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
+ E- A$ a9 G3 y( e$ z                       
# ~+ ~6 n  F8 M  p大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
4 o/ l. n) ]* F- L* b( Ohttp://bugscan.net/manage/node/83* }% e1 k! O" u3 Y' _
http://www.cnseay.com/2515/
3 L- r( K  c4 }' g*>
8 X' v$ O+ s- L! n) M: r$ q测试方法:0 B% @- v' W! B/ A; L# h$ i# i
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
& E  g% S! p) A# F% J2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径) n3 M: `8 m) I; Z
修复方法:9 }" y0 D9 x# q, u+ N. V
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:0 h) D: i1 X: t4 l9 v+ n
http://www.dedecms.com/products/dedecms/
8 M9 v5 O# \2 n2 V
4 k3 k2 @3 |6 y- b 临时修复: ( x2 X; k, W7 a; d# b
1)Include/payment/alipay.php
3 p" Y  D$ F3 L. [+ H7 ^+ M4 O  大概133行左右
/ v* M) [; J2 g+ s$ X  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';6 b' L% t& C5 E
替换
! i" ~! v6 |7 C  v2 F require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
7 D5 b; e6 F! ?. M& t2) Include/payment/yeepay.php
( ?( R' d4 L+ a" C- g1 i大概在145行左右
6 o0 I: e" k; F. @! I* y) g require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';8 N& G7 ^" C, E& x/ w
替换" n' {2 E. l* g8 b' t
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';' \" D# d0 ?  N8 A; l

1 g: q2 Z& V0 f$ @" I# Z2 A; n
回复

使用道具 举报

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

本版积分规则

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