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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
漏洞版本:
# d. |2 J4 L* zDedeCms 5.x漏洞描述:
) v2 l. k1 {% Y4 \. G3 ~, PDedeCms是免费的PHP网站内容管理系统。
  o$ \% Q% s9 o- m! G; `) F! ~8 X$ a! U
plus/carbuyaction.php里没有对变量进行严格的过滤- @, `* t# ]$ s1 H9 ]
4 S% ~- g) n0 p+ z
出现漏洞的两个文件为:
9 E/ @" l  p( i/ G9 mInclude/payment/alipay.php
. m& ^2 m0 A+ X' j0 D3 ?8 y$ G% rInclude/payment/yeepay.php
5 u% V- O6 y0 b) ?5 T漏洞均出现在respond方法里
5 [5 W: {7 X5 U  i4 s+ I7 ~* S8 q5 y4 h: B* X
Include/payment/alipay.php
7 H  M- T8 s4 z3 O" t......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
! |" W7 D/ q5 c  s; x1 T" H- K6 I                       
' t7 y  @$ f2 Y: l9 g0 z/ n* O/ E大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
0 S+ z4 s$ x: G$ r2 vInclude/payment/yeepay.php( K. G5 ~& x; V) G; N
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......, k: K: b. b- x4 P3 Q
                       
* h& l7 _1 j2 d1 [# I大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考5 R+ L& q, X" f& F. f
http://bugscan.net/manage/node/83
$ d( ~- n% Y. O; phttp://www.cnseay.com/2515/
+ v" o' t) N6 Z" m*>- y6 d3 _: w3 E2 y# V: N8 m/ F
测试方法:
, Z- P0 N/ j5 \- L6 @1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
0 E; N1 w# o" O" d' F3 c2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径$ T. m2 j) y7 k7 J1 E
修复方法:2 L& h4 `" d- T/ H, n
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:2 x* |8 I- T! ^' m3 K
http://www.dedecms.com/products/dedecms/
' i: q$ K/ F. Z' N$ x
/ B" T5 i$ R# O( g) V6 l' V2 | 临时修复: * |8 p& A( J- T  R' }6 X0 \4 ^
1)Include/payment/alipay.php2 t; l- T7 D" u0 t  @
  大概133行左右& T/ b3 R+ L; t4 I8 M9 F0 f
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
1 I% d9 K% i& J9 K8 n替换) W6 P  k/ v! B- }
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
$ i- O6 K- Q/ ]9 s- c2) Include/payment/yeepay.php
- Z  k5 s" O  P/ i' f大概在145行左右
) d$ k. k* p4 u; g# B# i5 Y1 m3 ? require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';7 N6 V6 w7 p3 _& j! T
替换4 x& m: t% s* c' ^8 k
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';! W2 j8 a1 l- E3 n9 G. y  b
+ k) g/ u, C! E3 a
回复

使用道具 举报

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

本版积分规则

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