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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:6 D7 b! L3 S: ]) ~4 k! S
DedeCms 5.x漏洞描述:  a: [4 b) b' n3 q8 b8 u
DedeCms是免费的PHP网站内容管理系统。8 E9 E5 b: z8 K9 G& q5 @

, H- `2 Q# x1 D; h' oplus/carbuyaction.php里没有对变量进行严格的过滤" @8 O; S  h& b8 u5 G6 n% x

2 W! _: B' S' V& y" P出现漏洞的两个文件为:) i8 x) D0 V9 ^, K/ o$ t
Include/payment/alipay.php
* I  ^$ t2 v- fInclude/payment/yeepay.php
( G: p$ Y5 N0 R& v6 R# L2 E漏洞均出现在respond方法里
% B6 A  r& e3 k: K8 w/ _* C5 E
. z: C, r- b9 ~5 q4 tInclude/payment/alipay.php 7 c  d) H6 Y7 t, V; V& v3 W
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......$ R8 e& m: Z- A% u5 f
                        9 h) ^  x+ _! v
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。0 e& i1 f% e4 m" a# L. ]. A
Include/payment/yeepay.php
- n0 O3 Z' q. o+ t! Y8 z......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......$ y' n. r1 _: u- h" T$ q
                        0 i$ a  v, W% p6 D9 j
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考, n7 \! Q* P8 t9 ^" e3 e. e5 |
http://bugscan.net/manage/node/839 ~( D) q1 L- R" k' e: J9 R; p* L
http://www.cnseay.com/2515/
/ N& [1 y8 v# c  R% s1 v+ z*>; {) f0 o' \% m/ y
测试方法:
$ X; o/ q4 q0 z" `2 j$ r. B- y1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
& R1 t' w( f8 I, X5 F2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
$ z$ x. J& H2 K修复方法:$ q2 @% D: s# U( L3 n
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
3 @  g2 A- z  xhttp://www.dedecms.com/products/dedecms/5 w+ L: r/ |  y. M0 ]

" v+ r# u; ^( b+ k 临时修复:
( [" `* h; s: M, k1)Include/payment/alipay.php
4 o8 O0 a+ f2 K6 L5 C  大概133行左右# b: _/ `# `- @  T" {
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
; {, T& ?3 H6 S, x0 x替换/ ~8 ^5 S% @+ X. s+ W
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
; B9 T" l; C9 ?. R( H2) Include/payment/yeepay.php
; T, J  i( e9 `3 Q大概在145行左右
+ O# ]+ W* G0 ` require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';0 n+ y& r6 C2 f* w
替换
' c( y/ v0 v3 B' z require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
  t$ Z: N" i% y. ^- T  J& j9 a# z , r  _# H* {" v! |, N% L& n
回复

使用道具 举报

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

本版积分规则

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