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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:/ b9 v9 ~$ ^/ e, s) I
DedeCms 5.x漏洞描述:% d& J9 d7 x/ E
DedeCms是免费的PHP网站内容管理系统。
) [3 h2 S: R4 m' L7 K' f0 i. d' c
& ?5 M* _0 s* S7 j& n1 s4 \plus/carbuyaction.php里没有对变量进行严格的过滤6 X3 b! x3 e$ o$ A
* q, T% e5 D3 I+ F8 B  o& z- J
出现漏洞的两个文件为:7 m% p% ?) _6 F8 Y- G
Include/payment/alipay.php
: u- s* K) M6 }  F9 t4 d5 o8 eInclude/payment/yeepay.php4 E" \' E2 F/ p+ s7 Z4 ~4 v  Y5 _
漏洞均出现在respond方法里) f6 V/ {, N; Q: e. [# u
7 H# R- I; u6 m  F7 a! d( U
Include/payment/alipay.php 9 g6 K5 X! ?: u- c, G0 E5 N
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
  X* \8 a/ V3 ~4 A4 ]1 i                        ; I& T: J: K0 C" A
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
1 [) P, O2 q( c: W8 Q2 {Include/payment/yeepay.php, n6 t5 u4 `$ F% ~, a& z! o+ M
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......: Q9 u3 ~* U6 \% f2 N" i
                       
% \# X* G7 N0 ]7 q' ~# I大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
, m! s$ o2 T; v9 rhttp://bugscan.net/manage/node/83, k8 j) x0 ~; ?- p5 `
http://www.cnseay.com/2515/# _+ ^. J4 s$ F4 t9 k; p7 y% H
*>/ J% z$ z4 U/ [3 Z/ G( o
测试方法:, o" \* F8 Z, f: M7 `+ Z) H
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie   c2 y. T/ Q7 M# ~( c3 O4 P
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
6 k9 u# @: j6 H修复方法:( n$ m/ y; O1 Z- l6 b" L$ _
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:2 _, h8 `9 R( H* c) R+ J; w# M
http://www.dedecms.com/products/dedecms/
% r2 U$ b2 c1 L
8 _' V/ |4 Q6 e+ W5 b 临时修复: 2 q1 M) q% ?/ q7 b4 {
1)Include/payment/alipay.php
. m- M" E' t9 A6 e- N9 S  大概133行左右
3 J# }5 Z  _# H7 u/ `$ X  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
/ n$ e# k& O9 c4 `, P( @( F1 U替换7 B3 ~. S% _! {
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
' O( Q- ?5 I6 E2) Include/payment/yeepay.php# P3 X( t/ a8 g; o0 \1 C
大概在145行左右
/ |8 R& q5 Y/ A0 a require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';( ]; k. D. O# J' A/ `' V
替换+ R3 z! O. v9 g7 Z) A
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
  s. a+ b; h$ ?) s' h
! i" d. q7 j' R. [8 i4 E
回复

使用道具 举报

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

本版积分规则

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