找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 1983|回复: 0
打印 上一主题 下一主题

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:6 n4 |) f1 H0 a( o9 S- f8 R7 _8 k
DedeCms 5.x漏洞描述:
0 t' Y( A6 m5 B% l. ^- PDedeCms是免费的PHP网站内容管理系统。# ~7 L2 M9 g; h
$ n0 P- Z# z$ S8 g
plus/carbuyaction.php里没有对变量进行严格的过滤
9 K' j9 U  |, H! ~# T
8 x+ Y: o  @6 W) @" c) L2 d+ G出现漏洞的两个文件为:
& d9 Q7 a, f' r, U9 Q9 z* qInclude/payment/alipay.php
  u" f" X7 s' a$ }  \: xInclude/payment/yeepay.php4 a3 z+ e! g2 `6 B5 f8 N
漏洞均出现在respond方法里. j; i) I/ s6 O7 T  x
* s2 F4 `5 v0 b: Y/ W  {" f7 h
Include/payment/alipay.php
8 g3 n5 V7 {% t1 P: T4 l/ c5 f......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......( @6 K; z7 r. h5 G; t6 K0 _
                        ! Q% [2 C# V8 [
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
1 s" Y+ `3 p4 o, x2 p; fInclude/payment/yeepay.php5 r& w# j* k* C4 f3 r. t- h8 m$ ~
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......7 Y2 M3 c/ C0 N" K
                        5 R. z. K: {- t9 O& w8 h: k
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
9 ^/ Y* x" ?) i0 `2 R$ l! shttp://bugscan.net/manage/node/83) L2 K1 p! U3 H1 r8 Q3 [
http://www.cnseay.com/2515/( N3 I3 B2 C/ d' `
*>7 q! Z6 l: D1 C$ k1 d: ]# Q9 \# Q
测试方法:8 D4 k% ?' q* Q! i; ^" I
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
6 Z+ b( ]0 o, i; ]' D/ K2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径' [6 ~  v; m; m2 P, I
修复方法:
, j& e& s) F- `' j4 n目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:! G( S" N6 G! K* w' c
http://www.dedecms.com/products/dedecms/7 x( `4 g% h4 x( r8 S! u) g/ C

6 g7 R. t- E# Q- }% U& u: W 临时修复: 4 t& k# W1 n& h# k: y: k* R* g
1)Include/payment/alipay.php
7 x( l. r& `9 r' l  大概133行左右
+ ?5 S: q8 q/ A0 M  A" V  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
0 K3 V# P( C( u替换; x) u4 E' V" j# ?: a3 o# m
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
8 M. [. D, n8 H; P2 ]  h; ^2) Include/payment/yeepay.php
9 R! o" U/ W; P. g' C( T" n( F) Z大概在145行左右2 {5 h# ^) k7 ]; M' y  M+ C
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';0 i1 }/ ^5 D9 b. A
替换. p2 f: d# t% [1 m1 G9 q
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';& }9 c5 d2 J1 @+ H. U

* Q' c9 ]* n" P  {: e9 C- g$ a& Y
回复

使用道具 举报

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

本版积分规则

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