漏洞版本:
; y/ v. Z. J" g9 N* y8 P8 |DedeCms 5.x漏洞描述:
2 d0 V% r, I0 ]8 t; Z* gDedeCms是免费的PHP网站内容管理系统。
+ w% u8 _9 ^ n Q
; j' ^$ d* c; | l* T- o( z' Iplus/carbuyaction.php里没有对变量进行严格的过滤
7 U+ Y% L3 Q! o4 o* r) M2 y8 J
+ Z G4 I* O9 R* M, s出现漏洞的两个文件为:7 O$ G' B' d) H% x
Include/payment/alipay.php6 x. a0 t) V' |" Y0 e6 j9 r& I
Include/payment/yeepay.php7 K' @ ~& _7 j1 y2 G3 f4 i+ h0 `& _
漏洞均出现在respond方法里# s1 y/ u: x6 o# d
+ v/ h+ v+ c' h/ ^. A) ~Include/payment/alipay.php
% Z" _& Q4 _! u......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
7 ~ K A/ X Z: J g 2 v3 \6 x+ ^4 t2 }- i( x
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
% g: q9 {. ^. p6 `0 ]5 b; FInclude/payment/yeepay.php1 Q4 b( C( P* t8 U7 Y
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);....../ E) {* l8 X* i v1 {; i0 G7 {
- {7 r3 r* ^8 v4 y大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
6 I5 T+ L$ O5 Z+ B" I, Xhttp://bugscan.net/manage/node/83
0 p$ C# _1 B- x8 Z1 w* t& m8 C3 xhttp://www.cnseay.com/2515/ t# R8 [* _$ }1 {0 N' M! U
*>
; R2 c7 k. @# [6 }0 p测试方法:# g4 ?# R0 `8 i! c( _
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie / b t1 K$ V8 R! L6 e
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
" P" ~, y- ^/ P& V/ z2 R, z7 h修复方法:
" A7 |% ~; m& @& f2 I目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
7 r9 p1 Z! U( m3 r; nhttp://www.dedecms.com/products/dedecms/0 q+ X0 x' g; P9 h
/ ~$ V# n6 X# o, b l/ k" ]
临时修复:
+ [! [' K8 }: L! n( ` g" n& C: X3 A( S4 O1)Include/payment/alipay.php, }) O% v6 y$ p# P0 K
大概133行左右( L3 Y Q2 r- `: b: v3 w
require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';5 e0 H6 G; P4 v. j8 d
替换8 p0 K+ n0 ~4 _% S! K1 _
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';5 K) C0 Q# Z) x& K2 C$ o6 U0 K5 m
2) Include/payment/yeepay.php2 F" P# E! B6 \% | x7 X- k8 O
大概在145行左右- [5 L0 J4 }) H6 ?
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';3 k. F4 Z$ p+ F( i! t
替换/ a; @4 F+ s( I
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';9 V+ V( x" X! v7 D' R
* [% F3 j' d$ Q& F# l |