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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 显示全部楼层 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:  ~5 g" \6 x& ?! P
DedeCms 5.x漏洞描述:
& N2 T: v, K0 Z; BDedeCms是免费的PHP网站内容管理系统。
; u6 O" C! J$ H
# e3 z9 K, K! o. ^& rplus/carbuyaction.php里没有对变量进行严格的过滤
) r$ v( }# f9 |3 J! K/ g8 }. A; J( f' M- v- U8 x: |, V
出现漏洞的两个文件为:0 a: O, t5 J3 R7 j9 U! w
Include/payment/alipay.php
( {; ^% p9 _  \9 rInclude/payment/yeepay.php! A- ]! Y7 f( O* j, M
漏洞均出现在respond方法里
" f/ i, _8 _: @+ b. P9 V! |' m) G6 L7 Y; X! ?: d9 f( Z
Include/payment/alipay.php 7 `( l8 k& N) e9 E
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......5 j# [- e( f. _
                       
; p9 u2 E! _+ ?5 p# k大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
, f; s" P$ `- Z/ ?7 N* i# B$ |Include/payment/yeepay.php
  A( \* N# _: u+ d9 {% v......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
; E* e0 \. u0 q1 }                       
; q& P1 m# r0 ^1 r- d大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
! ^, j/ v  u* v* n+ A2 i( ]( b" l. `, ihttp://bugscan.net/manage/node/834 G/ l* @% d3 K
http://www.cnseay.com/2515/
" E" T6 f& C' B1 V*>7 H& v5 c. ^0 v) d
测试方法:1 N( ]& f7 l, F/ U! w. r& W( P
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie : {: f( D9 `! W
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径  Z' I! M) q7 m+ a* K
修复方法:
% ~/ a2 P( k$ V/ a) d; {2 ?7 Q& v目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:7 t5 T. }6 ~8 @& g+ J
http://www.dedecms.com/products/dedecms// l! r$ M/ @+ n- m4 U) L5 B
* Q  A4 e+ V/ v! a& w
临时修复:
/ U0 E8 ^+ {$ Q6 `5 M" E1)Include/payment/alipay.php& a7 O- w# M5 X% f7 k5 [
  大概133行左右- V* i8 O% }  @$ y2 p2 F4 A$ \
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';4 k  R5 |9 q+ F) r) T) k
替换
7 U7 h2 L9 X6 D& w  O0 h: t require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
% k! b8 ]7 o5 E- i2 J- y2 J7 n" Z2) Include/payment/yeepay.php
% _! l. I! i" C* ^5 c9 j大概在145行左右
/ s# _* J& d: B$ n require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
. [8 ]' Y4 K. z; Q 替换6 |  Z& G/ l: Y. k( q
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
4 [! I# W6 f  ?+ @! S$ ]6 D $ a/ m' {0 f8 L5 l7 w- Y
回复

使用道具 举报

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

本版积分规则

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