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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:; r" ?2 j% C" G9 z! @  r
DedeCms 5.x漏洞描述:
3 B: c6 u* ^2 f$ V( d0 M6 H0 Y( PDedeCms是免费的PHP网站内容管理系统。2 z5 F! ?) ]$ {* v' F; n  I
2 F7 h! c  @/ w, U# _7 t) u1 y9 O8 ^
plus/carbuyaction.php里没有对变量进行严格的过滤
$ d+ {* B- }" q, M- m7 w
6 \  k* Z$ _4 |3 I- Q4 [2 J) q; {出现漏洞的两个文件为:
5 [) g5 q5 i7 f* h5 x0 d! ~$ K# ~Include/payment/alipay.php
7 v( t1 a) s& B) _0 q7 L1 V, {6 WInclude/payment/yeepay.php
0 U8 P' ~* D) a* y$ D/ K4 ^+ B7 W漏洞均出现在respond方法里; m3 f7 c" S( M

7 S+ f) G5 z7 c0 GInclude/payment/alipay.php
2 l; c# a/ }8 W% d) r5 p......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......4 W+ o/ G2 R2 T  Q5 t
                       
# P  }0 {- |8 B3 ^& P$ j大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
/ Z' a& g8 x$ nInclude/payment/yeepay.php$ C; \7 z1 ~) T( O8 @
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......+ x1 j5 f  k- L) M! w3 b5 \1 l
                        8 e# o: Z  D0 m& j+ X/ w: {$ T
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
" @1 T7 B6 L! L+ Lhttp://bugscan.net/manage/node/836 m, }- U( ^! J, O+ W" h2 I
http://www.cnseay.com/2515/
( M! j* m  u! U' t*>
1 h/ o. K6 L9 a测试方法:9 r+ B" O5 A  S6 l5 O7 [# _
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
  O/ E) y9 B0 H- q6 w* f# H2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径# f4 C8 o: f: N& l' t
修复方法:
1 i5 _# h  w2 v' J目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
( Q1 K0 Q# L, @" |http://www.dedecms.com/products/dedecms/8 _2 o5 s9 ?6 C  E2 Z" ?. z" l
7 l2 {! X# e+ p- L4 e  s
临时修复:
; R2 H8 T( n9 _; X1)Include/payment/alipay.php
) h1 n# X. [! J: v$ S  大概133行左右
0 H- M* f( q# I9 d  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
8 @; O4 c5 ?8 O% J7 _. d替换% }% ?* ?+ R; K0 i2 Z# y" M
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';+ e. s" I, Y8 f8 ^
2) Include/payment/yeepay.php+ M' w+ l  I% V& l9 O- J
大概在145行左右- a. G) n! `2 d% K
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
. L2 u# F. U# t: a6 D% s 替换) h9 p4 T6 o3 k8 P7 z5 K6 P) |
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
8 y3 \& V& @- E7 [ . m1 C# r" a7 X) s, P3 o' \$ l
回复

使用道具 举报

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

本版积分规则

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