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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:
7 s+ t2 c$ m1 S, y% _DedeCms 5.x漏洞描述:
: h1 p: k/ O8 e* x6 y' uDedeCms是免费的PHP网站内容管理系统。+ K6 O4 u5 {6 h

- p$ G6 m. O' C, ?9 Eplus/carbuyaction.php里没有对变量进行严格的过滤8 v$ n( S; C* ?
) }# ?: p' l9 V8 L7 O2 U5 ~8 e# {. x5 h9 f
出现漏洞的两个文件为:
# U) i2 x" i0 H) O' F5 V. r7 U% _Include/payment/alipay.php
1 d/ D- d5 J! A7 q1 m8 q0 HInclude/payment/yeepay.php
/ {. s" R+ m, T- {; S$ j漏洞均出现在respond方法里% U0 [6 H' l6 @/ C4 N
  f; c' k3 a2 B3 h) `
Include/payment/alipay.php . ~- L6 I7 W$ J) A  U
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......! S! F6 N0 m+ p4 r; S, N8 W* C6 ^
                        9 h( i6 F: m4 {6 |8 I
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。5 [" `5 M9 I( {
Include/payment/yeepay.php9 I4 f1 }3 v( {1 B
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);....... f6 \8 f- A  _
                        ( Y7 f3 g; b& a( A( S( Z- o
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
! {% y% u% N. z" h! q$ whttp://bugscan.net/manage/node/83/ J/ x, N8 c; N2 D( L6 q; i. i3 S
http://www.cnseay.com/2515/" M5 d6 p. Z2 L
*>
1 N3 J7 F4 u3 ?) n测试方法:
1 Y; C7 n4 ^- L" o) s2 J1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
/ a" ?9 a: g: P1 I6 h) p# b2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径. l' P4 T$ O* U- n1 S3 }: P
修复方法:
+ F) Q! B% w/ q目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:7 B, Y2 V: y# ^3 ~1 ]
http://www.dedecms.com/products/dedecms/" D3 d) [0 c0 O, a- s

0 \  R6 J) I: u  L 临时修复: 7 G) A/ `4 Z- [4 }) w
1)Include/payment/alipay.php3 ]" e  P  l8 a( U0 @0 @3 ~3 z
  大概133行左右
- ?$ D5 i3 q/ P; b  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';  [9 d( H$ r5 V6 o# z' \, R( d& J
替换
; ?2 |* b7 F' K+ {. W8 C require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';( H! }/ c; I5 p) C, Z
2) Include/payment/yeepay.php
0 x5 O. n! L; D6 G& |大概在145行左右
- }  x( C2 t. { require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
9 M& m0 y8 q% F4 ^ 替换3 D: y8 C' X* u# w9 v0 H1 |2 {
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
4 r. R$ f1 l+ }: j 1 o7 \! V7 l$ T+ L! O
回复

使用道具 举报

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

本版积分规则

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