漏洞版本:
. g; Y: x T; E' PDedeCms 5.x漏洞描述:
$ x' r7 d# w8 s L8 t; ?DedeCms是免费的PHP网站内容管理系统。
& p! M. L. P3 r5 A( w/ W, Q
6 C Y* U& k3 S) y" uplus/carbuyaction.php里没有对变量进行严格的过滤) e! l: \+ H% [8 T- e
) b' T+ k# D2 h9 j$ A出现漏洞的两个文件为:
$ ]& h0 x. Z# ` n" }5 b, G) R( HInclude/payment/alipay.php# Y; s" `0 M V1 W
Include/payment/yeepay.php" ?' g( {( G1 `$ B& M6 u/ D
漏洞均出现在respond方法里
; t! V" [) B$ L& n0 W( Z4 }# o7 e) _ d( u# f- d% P% g0 r7 e( z2 K# `
Include/payment/alipay.php
; X4 G! d$ N/ b' p. e: C% E" v w......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';...... c q: U) G' N/ V i
6 N6 S2 B- Y3 y5 @3 h. S大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
# W) e( U" }- K) a* N5 BInclude/payment/yeepay.php
" n2 }6 d8 [" R* O; i! c......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......* Z' A: E F! y5 O+ T T
$ S: S9 g9 D! z: t6 b) u+ ?' U
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
& `# p9 X7 n" \6 d O7 ^7 phttp://bugscan.net/manage/node/83
. ~# [# h4 E: t/ M1 b9 V$ ?http://www.cnseay.com/2515/3 v6 C0 F9 Q+ S2 W E5 u
*>
. k( @* P3 r! s9 p1 F; U测试方法:% }4 ~' x$ q3 V, {; h7 y
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie % m: m+ ]6 e0 ]3 Y/ r- {
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
1 k# m4 g$ N, K修复方法:( d5 Y W. p$ M- _
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
2 b; L1 V R: Y% Nhttp://www.dedecms.com/products/dedecms/
2 ~6 B0 I: A( U2 d5 e
0 K* Y8 H% @' j0 V 临时修复:
* v K/ R8 r, @- z8 Y0 y1)Include/payment/alipay.php
8 o T: K& h/ D- s, M z, k 大概133行左右 g% Q# Q9 |; o% M2 G
require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
, t; d1 x4 Z$ i' _' ?, \2 O替换, N- g* |$ ~: ~+ N) l: @
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
?7 h; K/ l+ O7 G- R7 E2) Include/payment/yeepay.php: ~$ Q2 h3 q; @) I0 z) |; w, M$ F- M
大概在145行左右
* D% n% g( S! ~ require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';4 W& G% K9 Z" z% J# ?' i3 p o
替换3 ]) r& I. Q+ R* F/ Z
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';0 c3 Q& U* c3 k2 }! w* y8 Q
& R# w" B2 V1 z# s# j2 ~* w
|