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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:
. x1 w4 e0 e: m+ J# H' E  aDedeCms 5.x漏洞描述:
1 v( N$ A' l; FDedeCms是免费的PHP网站内容管理系统。/ o3 a2 G1 J; N* E# a+ e

  N/ W( e# q  b  v/ yplus/carbuyaction.php里没有对变量进行严格的过滤/ K( q- x  [0 r. _+ _! [7 y' Y9 N

' b9 e6 \3 N# R% ^/ l6 D出现漏洞的两个文件为:
0 j. [9 Y: Z& B/ y. W; {Include/payment/alipay.php7 P1 w0 C% a" ^% C, W$ g
Include/payment/yeepay.php" B: {- v# U& o
漏洞均出现在respond方法里# i% U4 \1 L- s3 ?' d

4 w) x$ o) l, iInclude/payment/alipay.php ( T7 E3 T! x* Q( @+ }
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......* C- H& A6 G7 l6 w
                       
2 M# x! h( x, O2 R大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
. O- A0 z4 F& ^. P, I: O8 cInclude/payment/yeepay.php1 u. j; b1 k$ K# C
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......5 {( O, E" y5 S
                        5 c$ n  _9 D6 n# S  y9 B2 e
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考6 h* d- m# Z/ p
http://bugscan.net/manage/node/83
& V( v& q6 x  d( _& ^6 {http://www.cnseay.com/2515/5 m+ \8 t' e/ j1 D7 V; c9 j
*>
9 z. W6 H" |6 d/ U* t8 ]测试方法:1 g+ {0 ?6 e7 c. V, h* V1 l
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie % T% L+ X: x# C1 F3 n5 C3 h5 C0 v
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
+ f) H  h& P& I+ k# }修复方法:) l* r4 D; v8 y' o7 R. j' l
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:' `( O6 H! K# _$ D
http://www.dedecms.com/products/dedecms/% N- Y/ }+ @6 [1 i3 @

) o" _& a; j" | 临时修复:
1 {$ r4 u1 T! B$ L1)Include/payment/alipay.php# l' n( J( S: g3 X5 Z
  大概133行左右
0 _6 W, y" S/ R" Y1 I3 R- Q; k& j  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';, t) v6 e, I1 K. K- E' }
替换
4 v8 l4 o2 I. k! A7 k require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
' `" N4 s% d3 `% W; U2) Include/payment/yeepay.php
" S5 C/ \9 [/ ?2 a大概在145行左右
2 E  H8 @6 |: F1 ^ require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';$ U* q" V( }. X' k
替换0 m' [; l6 u# O& K4 j9 Q
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
! y' U0 x/ x" F& A% | . X7 l  M$ q& ~
回复

使用道具 举报

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

本版积分规则

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