漏洞版本:% p$ w- d6 D* |3 S# p
DedeCms 5.x漏洞描述:- d( j( s* Q* v0 {7 Z
DedeCms是免费的PHP网站内容管理系统。
* L, L2 F1 _9 L" m/ [( F% ^# z* }* W/ o
plus/carbuyaction.php里没有对变量进行严格的过滤
9 C- T1 _ o3 {& A
7 l, H7 \6 B0 h出现漏洞的两个文件为:
' G+ l9 J% U5 t3 j/ Y4 [Include/payment/alipay.php4 y6 y5 p/ p6 m2 x" p
Include/payment/yeepay.php
/ M/ i! W# z. T/ P r" m- `漏洞均出现在respond方法里
* k r% D* [' \5 ]8 Z
2 E& O1 C, u9 u. w2 @" T! B/ pInclude/payment/alipay.php 0 n$ s$ r) q1 `' U, |4 L
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
$ N2 s* j0 l, L, D& K
! x0 d8 \" [, i# P8 d大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。; q% z7 M# X6 [% P9 P
Include/payment/yeepay.php( E% P7 q! [ |- W
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
5 P: \8 f2 u6 f7 Y5 b+ q
! @/ [" \% r* S0 j) z. V4 p大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考) n/ u" N' V$ z+ {6 m1 s2 n
http://bugscan.net/manage/node/83) ~5 t7 ?+ h4 T* b
http://www.cnseay.com/2515/* k, V; X0 s e" y" a6 u; g
*>2 ]$ J& W4 V& e* U! |& I# k
测试方法:
8 m& ]" [2 Q7 M4 I. I1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie ; w- B# R: b0 p! Q! Q" @
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
; g/ [6 L' l+ V& P( {& a4 t, ~修复方法:+ V& {( B g. I
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
+ D! @% O- C6 q5 h% I9 }9 v. o- }1 nhttp://www.dedecms.com/products/dedecms/* R# V- e* u: I @
$ Y5 Y1 l5 ~* F/ X" a, t 临时修复: ( @- {. A" u$ i6 D* s2 J# J
1)Include/payment/alipay.php
4 }/ }+ d: X- y* X F 大概133行左右3 C% q6 v7 K0 }4 d0 L4 L: F- a
require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
2 J5 @4 a T- O. A1 o替换7 Q# v% T: ]; v' S/ N
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';1 M2 C9 ^( G5 s7 a/ S$ J* u* l/ V
2) Include/payment/yeepay.php
+ G& h, g! c! S: t$ g9 l大概在145行左右
, S* S1 O. E" p# t require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
* `& y; |9 j( V& z8 {. W 替换4 ]' m/ E3 l$ v* t: r. Y' k
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
# `( \9 r; a5 ` $ u* m" l0 k+ x1 o& p& g! [& l
|