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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:5 l; N& X4 m  G' Q
DedeCms 5.x漏洞描述:
( c- K7 Q; y3 t5 c2 |, ^6 FDedeCms是免费的PHP网站内容管理系统。% r8 ]+ v2 Q  E" [* J, c" ^
  I' L3 f0 h) c: \0 |
plus/carbuyaction.php里没有对变量进行严格的过滤
4 D& x& [% t7 Z5 w3 U0 r7 M# Q" m- I+ ?6 ]
出现漏洞的两个文件为:) `! K' a; d3 O! M8 G
Include/payment/alipay.php  L0 _3 }+ |6 z( w: f5 _* v( _
Include/payment/yeepay.php7 F* t9 Z8 f* L4 T9 k3 H8 d
漏洞均出现在respond方法里
& y- _" v9 e! R4 b0 e+ T
- B8 q4 j! k+ w' S6 z( GInclude/payment/alipay.php
3 e( s) g# E6 S( p7 j! I......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......! \& R' g) w7 l; o! x: C/ J
                       
, C$ f% u. z% D$ V大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
( s+ ^, w; H( e% qInclude/payment/yeepay.php/ ?8 Y; Z: F2 {4 ~0 g8 N( ?) E% j% G
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......( x# [5 f$ F2 K# D3 T% O
                        3 b& R% ^4 u9 a: I3 z  f* Y
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
& Y9 y2 W4 @: H2 _, W3 \" q  Ehttp://bugscan.net/manage/node/83/ c" w: n% `7 M2 t. T5 E5 g& ~
http://www.cnseay.com/2515/
3 N& e) }8 J9 u2 K8 h6 W*>
$ h4 M4 y  B8 r& G测试方法:
6 R1 S/ L. j! K9 h( r0 d1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
5 x) j) f& K/ T" H) a$ F7 n2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径5 W& J' b1 X! o; E/ m9 s# C* h' Q. d
修复方法:
( m; L, E* z6 m目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
8 R( {% Z) U1 C- hhttp://www.dedecms.com/products/dedecms/8 m/ y, f4 E3 i& `7 O: [

" Z% i+ s2 y3 D" J8 j 临时修复:
5 b/ d) w/ o) G5 F1)Include/payment/alipay.php
! F7 z  k3 f0 R% H1 A$ P. \  大概133行左右- f1 s; x, l5 b+ Q
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
: Z! b( }. [2 m0 g3 F( w" ~替换- q" T" E: L& x9 i  l& x" t
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';* m( t9 I1 |1 P) B  S  |" N
2) Include/payment/yeepay.php; _! p: U+ {* x0 Q4 c$ `0 P# o0 ]8 \
大概在145行左右& Q8 [6 ]% ]" s0 t8 o
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';4 H: a/ ^- I3 T/ Q; z
替换
" F" o8 F1 W  i  Z* V/ e3 ] require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
) |9 h! _% g/ X6 N" Q4 F
2 q9 e6 a  a1 D# m4 D9 G$ o
回复

使用道具 举报

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

本版积分规则

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