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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:2 |& J2 m: ?% f( K- _
DedeCms 5.x漏洞描述:
* k$ p2 _( n' {/ O/ G( }2 x& R( dDedeCms是免费的PHP网站内容管理系统。; G  x1 h6 a4 h( `2 P" |

& m, o3 u7 `6 Y, n- m- Xplus/carbuyaction.php里没有对变量进行严格的过滤: B- H* b  O4 f  R
7 c; @! z' e8 h/ l# H
出现漏洞的两个文件为:( h; k3 R2 [2 p% R, B
Include/payment/alipay.php( g: m1 f: M& T; J
Include/payment/yeepay.php
9 L1 d% ^3 W; M$ P9 b" d漏洞均出现在respond方法里
  W3 G; m. Z/ U, R  W1 t2 a& _+ T6 k: h5 c% w4 G5 Q1 n; `$ y4 k
Include/payment/alipay.php 2 N1 Z1 x( T9 J! ~; Q1 w
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......+ k% F2 v3 T+ j+ M8 T  m& E
                       
5 A, h9 @6 v3 V9 o; S大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。5 j8 e; H& t/ f" i) u" D5 ^$ {
Include/payment/yeepay.php, z+ n' G" C0 O
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......% }8 f' k- u  z5 r
                        ; K' d- [( r4 c# q) y5 G2 M
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
9 l: i% }* l6 e/ g. B- Ahttp://bugscan.net/manage/node/83
4 C$ g6 q2 F1 o% O# ~* O+ T  @3 Ohttp://www.cnseay.com/2515/
3 O% ]; u5 o$ ?+ K2 T*>
* ~- Z- ~' _5 {/ v8 D2 ], S* Z测试方法:' ]7 F6 h# o: c# B9 A$ w) I
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
" C% D- I7 K6 Y( g2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
3 Y% D4 a1 S2 c- X) d( W" x0 J修复方法:! \+ S5 I9 r2 j4 M" _, O- E
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
6 Q8 \, R+ J) M5 w: q7 shttp://www.dedecms.com/products/dedecms/
% w9 k6 c! T0 k; E
0 g* q7 [9 D' R: c; M 临时修复:
1 K; s, h5 V, d' U" |% N1 {1)Include/payment/alipay.php7 K) a7 G* w  A- a
  大概133行左右
1 h" P  ~4 ]2 O8 o* p% d  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';" R: u: G$ N! \5 r3 R
替换1 k! Y  H% ?/ |+ n( |" V) ?
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';% G, T& B" E6 \$ K2 }
2) Include/payment/yeepay.php
$ d+ k$ ]% O$ R4 F大概在145行左右
, V, ]% i$ n1 ^6 A require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
2 X2 R/ [0 W$ }+ o, E 替换  e7 s. y! O5 `
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
0 t8 k% G6 y9 P, r) R1 Y : n/ `/ o! X# p6 b; U* [  X
回复

使用道具 举报

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

本版积分规则

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