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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:
  y* q4 R0 w1 @9 i! g, p) rDedeCms 5.x漏洞描述:) G* ^# c' N' v8 p
DedeCms是免费的PHP网站内容管理系统。* }/ v/ [1 l- V8 n
+ u) i* h. S! a  u
plus/carbuyaction.php里没有对变量进行严格的过滤
. S6 A# b; D( ~1 l7 H4 D+ Q8 r- W. k7 A
出现漏洞的两个文件为:
: n$ r2 I0 Q; ~1 H3 n4 q& v1 A" FInclude/payment/alipay.php
9 S5 L, G( S/ s/ F0 B7 tInclude/payment/yeepay.php
0 j: q# @$ S6 M漏洞均出现在respond方法里: A3 I! `1 C2 A7 T
' |2 O& a+ q7 o) P6 c
Include/payment/alipay.php
* N* q) p" n! r% k( O4 f......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......: a% L! l9 X! X: P* ~# m; V
                        + s+ W% x9 I  b) B1 W  z: }. c( q
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。( H. a! e0 [9 c! k; X* X
Include/payment/yeepay.php
3 r$ G" e# ]" ?+ \: O  r( M......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
9 V, g& a! V8 F5 \. F) x! B                        : x( j: W" W" ^. v
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考2 V0 b$ k$ F. j
http://bugscan.net/manage/node/839 R+ R  @$ E+ B4 E$ V
http://www.cnseay.com/2515/1 U3 }4 x; \% G7 M
*>
- l: d8 g  G; v9 l- a测试方法:6 O$ m. A9 n4 K8 @
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie / B1 E+ v$ E, P- \3 e. m, R
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径2 U+ j# @7 t) x$ Z$ d- d1 O
修复方法:/ T  I! r$ T0 a- S2 k8 D# r
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
5 O' E* a, m+ G8 f1 Phttp://www.dedecms.com/products/dedecms/( k" b4 U4 s+ M- t) E+ g
7 I0 r  R/ N: ~% a' ?. N
临时修复: 8 P+ n. Q: j) h1 s  o# Z" g) e
1)Include/payment/alipay.php3 H) Z. X( q8 O+ d& l, V
  大概133行左右8 ?  `% H. z( @; _9 e. O0 r
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';. j. N: H! Z1 x3 u6 ~, ]) O1 K8 R
替换
: e% U# C7 p" F4 j require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';9 R  Y2 C& M; c  L$ e- y
2) Include/payment/yeepay.php
1 T4 J  l0 t) x) P4 s0 g大概在145行左右
7 \# q7 V) l: T: f require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';. ~$ T: S$ Z, ~+ \0 n6 w: t1 P
替换
! t/ b5 S2 C, E; |- \9 R4 B require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
6 v$ |$ k9 y! Y& [- Z 2 Y; @, r5 h3 p1 h' t- e: C1 K
回复

使用道具 举报

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

本版积分规则

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