找回密码
 立即注册
查看: 2342|回复: 0
打印 上一主题 下一主题

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
漏洞版本:
, X4 ^0 U* B9 f" J' ~DedeCms 5.x漏洞描述:( L2 |; R. H# c. e% u8 f1 R
DedeCms是免费的PHP网站内容管理系统。
; a' ~. H" k- c- E" d8 f' G/ @2 P
plus/carbuyaction.php里没有对变量进行严格的过滤" _, u( i2 ]5 p! f/ O0 ]2 ^

5 Z1 ~6 `/ n  n出现漏洞的两个文件为:
0 N7 b8 j6 K1 w7 u7 L# }Include/payment/alipay.php( ~3 b, J$ A' j1 \9 P% i1 K5 {
Include/payment/yeepay.php2 t4 h' e9 C! s2 }2 N
漏洞均出现在respond方法里7 I. {* y; l# X% p9 _
# o5 R* i& x; N% h6 t4 S9 ~* H
Include/payment/alipay.php
: p8 x" L$ V. O7 F......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
7 ?4 W( Z9 G! W% ^) w                       
% z  S0 x$ R1 j% d: z大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
# O, q0 z( K0 C' ~' `& ZInclude/payment/yeepay.php
: J& `7 F3 I  t: r1 [5 j......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......! Q9 R2 L: R- m( Y, ]0 a
                       
1 G6 n, M0 p+ {6 D! J9 F8 b/ ]大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考9 t- y* X3 `+ l  p* F1 Q" ]
http://bugscan.net/manage/node/83% s* t% e% G7 M5 ~, G
http://www.cnseay.com/2515/
2 H" e# q* u* F$ e* H% b1 y*>
$ u+ _/ Y7 v) A2 p( [) ]测试方法:
, s6 o% r( \3 y- v7 p9 Z1 V- O1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
0 Q; A* j6 y$ q  F0 L2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径4 H$ g1 ~2 \3 @3 V3 W+ I; W% Z
修复方法:
3 T6 Y; W% K5 f( ]; L0 l' G  I目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
. A8 A6 y0 }. W; m4 }http://www.dedecms.com/products/dedecms/
1 W& P; n8 X3 l) i& d4 p0 `- T# O4 Q1 S
临时修复: % {* [# }2 ^2 a8 i
1)Include/payment/alipay.php: _; Z7 x0 X. Z
  大概133行左右. u  V1 }. @! n
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';3 N, c0 t, k+ y; A6 q) V
替换
* i0 v$ P1 z4 M7 q, A3 a4 [) w8 t require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';; u3 C) U( H- l) M) w2 F, P
2) Include/payment/yeepay.php
- F& S- u% r/ d- B4 u# W5 ]大概在145行左右! K1 Y7 D! p1 C% e: ~# ]
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
/ V+ d+ {9 w' p0 C1 q' K% `( ? 替换# q3 z. u6 S7 \. j/ ^
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
: v9 k, ^% c# w8 {8 ? % Y6 E+ ~+ v6 a! Y! ~
回复

使用道具 举报

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

本版积分规则

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