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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:! |) X9 N1 z6 b
DedeCms 5.x漏洞描述:
8 e: ?5 `, ^) kDedeCms是免费的PHP网站内容管理系统。
+ A4 B. ]. p. `( Q8 Q' g0 N/ e2 O' {1 X
plus/carbuyaction.php里没有对变量进行严格的过滤4 ?, \3 ]$ \& w8 j. n

! i- o9 m- n% y, h出现漏洞的两个文件为:
# F, t- x9 b- F; D: P3 JInclude/payment/alipay.php
+ q9 Y$ O/ h6 G. B( ]( P$ pInclude/payment/yeepay.php. O, m- ]$ v. L
漏洞均出现在respond方法里
+ z4 |" m8 `$ C+ ?
5 Z3 _7 _4 C  z* E2 oInclude/payment/alipay.php
( t+ B  ~1 D1 o6 X5 i# b......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
* Z$ f! B/ e( q! K2 w& B8 z                        $ S! S* }' ?: ^3 b/ M0 ?; g/ _0 b
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。3 _* A3 x0 S5 I6 _
Include/payment/yeepay.php
, q0 ~" t9 Y1 b. p' c6 i! C......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
; ^! P; E7 g9 i2 J5 _- b& W                       
) C" ~' V$ o% `2 Y9 u大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
1 U2 ?: f: ]' m; Ehttp://bugscan.net/manage/node/83) g3 E5 C: c1 o" A( \  g4 c
http://www.cnseay.com/2515/1 b0 @, U' z2 h
*>% l: {( b" H  E
测试方法:
3 U3 c7 t" A4 L1 X6 ^% C9 R1 k1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
/ H0 u1 Z: K- k( W7 J2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径. M4 j4 g! n$ E/ H% @( s
修复方法:) @' w4 X7 s8 A- L3 ?
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
' w$ g9 V# }5 ohttp://www.dedecms.com/products/dedecms/8 t: j4 t1 T% Y$ l

+ I0 m/ h1 d5 U& S: k5 ] 临时修复:
$ k4 D/ Y. n2 m( c1)Include/payment/alipay.php  E! h+ c' C" j+ j' X; N5 u
  大概133行左右' l! _1 p( R, X
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';- }  k$ M) h! N0 h! T8 E
替换: O! F/ W4 Q& \2 ~2 u
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
" X7 b& I) j4 Z) c0 P) m1 g# O$ M2) Include/payment/yeepay.php6 |& }* A# l( K/ v: M6 D; v* F  W8 |
大概在145行左右
7 L) c2 \8 b% O. v3 |# s* g require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';8 ?) |' _; e1 w+ n
替换
- d2 w2 ]- O' s. ]: ~4 ~5 T require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
: b9 E7 w1 U; | " W, l3 W3 X: @* C5 o  ^7 j, j% i
回复

使用道具 举报

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

本版积分规则

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