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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:
  Y; Z$ ?8 r( {2 o1 m# aDedeCms 5.x漏洞描述:- _" J3 `1 X0 U) s2 q
DedeCms是免费的PHP网站内容管理系统。. S  N* `1 O. C) g! j1 X
) z3 K+ }4 }% J7 ~  p
plus/carbuyaction.php里没有对变量进行严格的过滤9 T( w8 G% ]. y! F; {1 h: V, q
  x% r+ u- v3 T
出现漏洞的两个文件为:% s! }. T" I- f
Include/payment/alipay.php
4 K3 i; R  a  g$ c2 _0 Q2 ~Include/payment/yeepay.php
7 |7 }& C! i: s$ i) B, o: f* n  C漏洞均出现在respond方法里$ I1 w5 I8 _/ g4 W1 q! Q" Q6 T( u

' i( z1 f0 ?7 Y. _: [Include/payment/alipay.php $ g. V+ h0 J0 g  ~3 ~7 h
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......( u& x' c  J: }0 ^: k3 N0 N; u1 S
                       
  b0 J# g+ l" k' d5 q8 J  Y大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
3 K- |" o1 V, }+ R0 |Include/payment/yeepay.php
2 q- k) V2 n3 q( Q! S......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......: v) t" K* {) p! H5 l+ i+ K
                        , s, X! z$ P2 g" f3 o/ j
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
& k: g# @0 l7 |9 s; _3 \http://bugscan.net/manage/node/83
3 }2 I  o5 w- ~7 B7 v- H) p0 N  F* mhttp://www.cnseay.com/2515/  H" G& ?/ X, n6 G
*>
7 Q* D& H& O6 H, t测试方法:  W2 A' S/ s1 ?% w: o8 E$ ^
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie 0 K; M6 B4 P+ ]; E: c3 D: h, ?: [
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
6 h3 X. b) L# @  k: R. o- q修复方法:0 z  o# s$ Z6 U- `/ o5 K
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:& d* L8 l' V+ q3 H! z  E# a0 X
http://www.dedecms.com/products/dedecms/1 d: j4 h* [3 n9 M7 p
6 k0 O* u8 T0 |1 G- Y$ f# z
临时修复: 3 l9 ?- I$ y6 b1 N
1)Include/payment/alipay.php
0 Y  I. z8 i+ ^4 K9 z7 C  大概133行左右( X% O: c+ e) _( ^  {1 v
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';8 C" T% I7 M- k- {4 y+ Z
替换
( Q7 U. J+ C) x0 \. B require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
5 q, b/ o% R0 u! n+ O# R( u' N2) Include/payment/yeepay.php5 x* I9 d) o* U. T- e
大概在145行左右. X- c' y1 Q7 d9 j
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';% Z0 }8 g7 n* M. ~, A+ J
替换* |/ y) a3 z( h- `* U- \
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';5 @  K: t8 [* y8 K6 K. E
* E3 ^7 p! `7 O
回复

使用道具 举报

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

本版积分规则

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