漏洞版本:/ b9 n2 f$ O/ V! G6 T R4 f
DedeCms 5.x漏洞描述:
( }5 T, [% R @) a! G) L. U: f. ZDedeCms是免费的PHP网站内容管理系统。
% n, w$ e% A& B7 [" g$ A; ]- [3 D/ n) P2 R5 o
plus/carbuyaction.php里没有对变量进行严格的过滤
/ o' v* [+ d8 h( L. L3 O& Y$ x$ n# J5 w g8 `& c( o
出现漏洞的两个文件为:
/ s, ?8 N9 `& q6 `: e9 CInclude/payment/alipay.php/ R7 T# ^' f, U, n) v" }# [$ S3 {
Include/payment/yeepay.php* ^2 r: V8 W' b e
漏洞均出现在respond方法里
; I8 B$ A' l9 Y/ s" A
+ \2 e( h, G! B/ ?& W9 X. bInclude/payment/alipay.php @, q9 g, {0 U4 n6 y+ V5 t( n' K w5 O
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......1 f; H; `. _$ w( o6 j7 X4 f$ B
. X9 i2 U) `% _8 T; ^1 x, q# [大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。 T7 X l) g, m2 N4 Z, r
Include/payment/yeepay.php2 O* c3 v4 m% ^
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
# r* q h/ K4 l& g* U. ?9 u
0 x" D' L; C1 P k# V6 A) V4 I大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
9 g( R5 e4 T# O' Whttp://bugscan.net/manage/node/83
" K# W1 S# }* s9 C' vhttp://www.cnseay.com/2515/0 X9 D( x7 N5 I
*>
0 D% [0 y+ |2 z8 u: N. @& p测试方法: N1 t) ^8 w' ?* D/ \
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
' V3 B. b1 }$ U, E2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
! Q9 E# @1 n1 |+ s& A$ J, ^修复方法:
) X. S) _/ m' v1 {& N8 m+ k# W目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:& v) a/ t7 @5 \2 K9 a" V: p
http://www.dedecms.com/products/dedecms/7 D9 r: S; N3 |. d7 `; t5 H
: u2 b' k2 q3 V. e, S 临时修复: / j9 h6 |! ]# y/ ?% y
1)Include/payment/alipay.php
1 H, x. l X" `. P8 i8 K 大概133行左右8 w- R8 Z- M+ b' H9 m, I5 y1 Z7 K
require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';* A/ x1 W. e" y! ^3 o5 K; X
替换
/ i3 ? b2 I# C$ p: J require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';. l# S4 I2 I+ @% m
2) Include/payment/yeepay.php
! j: i& i h7 @: B( S% N大概在145行左右0 o6 R- A2 [ X3 ?
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';+ _8 d1 d t* K; K7 E5 P
替换
) |# J- ^- S- u } require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';. j% e! c2 W3 x: Y J
8 {' Z/ O% }. {: b5 L" z |