找回密码
 立即注册
查看: 2339|回复: 0
打印 上一主题 下一主题

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:2 ?4 y! {, _7 @- m+ p: t6 W. q/ j+ Q
DedeCms 5.x漏洞描述:
9 N% N: ?! s& l& m! _* cDedeCms是免费的PHP网站内容管理系统。
# S; k1 ]' ~5 x1 |$ C& f# ]# z; M) N% N
plus/carbuyaction.php里没有对变量进行严格的过滤
- ?) n1 @( j: o3 s) ~# D
8 G: R) m3 A, u2 Y1 v* }! `出现漏洞的两个文件为:6 I1 |# I* V+ r2 s
Include/payment/alipay.php
; B- T  p1 a5 z. H( y, EInclude/payment/yeepay.php/ z! g9 ^  p5 Q1 u
漏洞均出现在respond方法里7 W0 H+ [2 m- A) y

( b, T- [; h" V  Y) uInclude/payment/alipay.php 1 U/ m: I( }7 \4 c% z
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......, x3 _+ J7 a( v: H* O; n6 W
                        % C& S; W* g; U3 i5 J) g2 _
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
5 p* G: O: w1 T- C* V- EInclude/payment/yeepay.php+ @8 V9 G7 L- |/ w& L* h5 v5 q9 W  ?
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......2 D8 g3 i6 m2 J( R
                       
$ Z! |: d! N0 s, C. \& H大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
4 I& [/ B- {7 m& J" Ihttp://bugscan.net/manage/node/83
  W" K, N) a. zhttp://www.cnseay.com/2515/
( \( @3 v, j/ M/ s*>' ?+ w; g' I( g! S! N
测试方法:7 `) \8 V8 X2 L2 |
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
$ t/ Y( A( X3 b: m3 D2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径8 i5 W5 V) O, c$ x& O$ e
修复方法:/ [  [8 ^4 Q. g5 i
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
2 w0 b1 e5 L" ?3 Z0 Y/ M6 Shttp://www.dedecms.com/products/dedecms/
, c& G1 s; E+ D4 k1 ?+ g: v1 C, X1 f" }# _4 d
临时修复:
& m$ C- c. M8 x! r& F9 u: U+ @  Z% _1)Include/payment/alipay.php" v: x" g7 I8 R+ {0 C
  大概133行左右+ U, I) S( j" p3 {
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
" C9 K0 c3 w- c4 d替换: @9 s4 F+ s6 I4 U2 z- Q
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
: K2 P% Y$ n5 B; t3 Y6 n7 y2) Include/payment/yeepay.php
! m1 O& i  q3 J3 N9 V大概在145行左右
" U" v' Y/ S! O8 J require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
: o8 S1 r0 M. b+ z% ? 替换
1 _8 M9 f& s6 g& k require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
/ |1 s# h" c3 P! { * p" Z7 \7 t7 r6 X/ R6 m% J
回复

使用道具 举报

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

本版积分规则

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