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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:
3 Q- y5 I7 D6 I& G6 m6 `DedeCms 5.x漏洞描述:! l; U8 b5 L( E8 J+ z+ L  D
DedeCms是免费的PHP网站内容管理系统。) N: x1 @" \7 n6 v5 U& j* X
# x% ^1 w+ q# s' S6 P/ @; Q1 U! L
plus/carbuyaction.php里没有对变量进行严格的过滤
% `# E; p, H- S
- X( Z( [, B. w8 G出现漏洞的两个文件为:
8 ~4 P7 u7 j' G& k# p% x7 R5 MInclude/payment/alipay.php/ V$ {/ H: h; w7 l9 ?
Include/payment/yeepay.php9 L. o- V0 a. q( J8 D, O& ~
漏洞均出现在respond方法里% }! i; j$ K* Q" n' u: h
0 w$ s% Q: u3 c- p& ~
Include/payment/alipay.php # [$ N9 q8 H" g, t2 r( ]
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......+ [5 X5 d3 K3 L0 q$ S) g7 I% B# C3 A
                       
+ k8 G) c3 K4 X; R7 x* _" z, K大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。4 w; G3 k( U7 g1 \$ x% `/ Z
Include/payment/yeepay.php
, j" F3 q! @( J9 A: l" c5 Z7 n......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......% b0 Q4 T. \: M& Y* m, L
                       
+ W" |* A( q5 n: ~5 X大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考& ], A( \( z. M! q% U
http://bugscan.net/manage/node/83
' {3 k' Z( Q. z% D) Vhttp://www.cnseay.com/2515/
* Q5 d( }( |: F- g3 x& s& ?2 [# b*>
7 k7 V! r, u5 `6 r测试方法:
5 d, g. o; ^$ W' [1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
9 A6 {& q7 D! a  V1 W- L+ X2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径. L. A1 K: T2 W/ D
修复方法:
7 M5 r: _4 f3 s4 F9 C6 W$ [目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
4 b9 ^( p6 B4 b5 R( chttp://www.dedecms.com/products/dedecms/
+ t& R4 _+ N! P2 m
' w4 \2 V1 F  E: C- G# F8 J 临时修复: " \/ a% ]6 |9 w
1)Include/payment/alipay.php5 K0 ~9 y; x) {& ]0 R- q" R
  大概133行左右
7 `  H# K/ U) M; v4 F, _9 P. u  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
) B6 ~8 ]( N  z% t) e替换4 c2 ?% Z6 U! ]7 J; ]4 B
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
( Y6 V" \4 F- g5 x) Z5 j* f2) Include/payment/yeepay.php9 B* Y2 k6 u+ u  S3 c
大概在145行左右
2 d% R  T( W7 R require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
$ G' g% M% i0 @4 l' @) n9 _ 替换: x9 I, D0 r& h
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
8 C4 \% P, W1 s+ |
* f4 j( f& ]5 s+ S3 O6 Z; X
回复

使用道具 举报

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

本版积分规则

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