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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:0 D% P: F! i9 \
DedeCms 5.x漏洞描述:
6 w& k& [3 ?9 I5 ODedeCms是免费的PHP网站内容管理系统。
; N8 x, q# S$ b  p+ d) b/ h& s3 J9 Y3 f' T7 D; N8 D0 L
plus/carbuyaction.php里没有对变量进行严格的过滤
$ J$ K  @% z; {' \0 _+ B+ `
$ [1 {( {5 m. j% n: o9 B% R出现漏洞的两个文件为:
; U- w7 u  o% R5 S3 W3 WInclude/payment/alipay.php
, y7 d% a3 k: Q9 s! |Include/payment/yeepay.php
8 `6 P2 q) E+ P) G漏洞均出现在respond方法里$ @; U6 J  M! b3 i- a5 `; c7 S

1 N8 P" S. J: @" ~0 KInclude/payment/alipay.php
+ w) t' A  L( r" f. ?5 s5 j! R......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
1 J5 ^, M% T  S" |                          \+ C7 ~& Y* I
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。. B' q7 ]6 N* J# a* A6 D. B1 J
Include/payment/yeepay.php
7 q2 R( F% s: Q6 U......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
- w; M* r2 ~$ T. o5 ]9 a9 e                        2 P2 C4 a6 |. ?- ?8 F
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
3 E- a- C1 G0 ?; \5 jhttp://bugscan.net/manage/node/83( c2 C  E9 G- R4 w1 _  `7 w, ?
http://www.cnseay.com/2515/
# Y8 ?( W& m! `2 A+ \1 w$ G0 f) Y*>
- o: p5 @- ]! a3 v* v# u测试方法:
4 _% _" E: N+ u1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie " ]1 ?, _4 }6 c; H" ^/ A
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
1 E; w. p% T  V+ Z* h, o' m修复方法:4 i; ~6 {+ k6 @. ~' G8 }& q$ q
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:' u$ e( @2 P: r9 ~3 M8 m
http://www.dedecms.com/products/dedecms/
) C- f; y2 R5 L; n1 o- X$ Q
; R7 r' J2 |$ R" p) B 临时修复:
, f( ~9 H6 W$ a- f1)Include/payment/alipay.php
# j+ d  F, f: x0 e3 v3 |4 U1 ?  大概133行左右/ [7 l' T; W+ v! _5 U6 n$ v2 f) N
  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';# l4 m* i0 m' b2 i
替换
/ Y$ H; g9 T9 I5 n# e8 R require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';; F( b1 L& N7 \# a  o+ ?/ @/ v
2) Include/payment/yeepay.php
3 S' t: z( k( u; ?5 V4 j大概在145行左右
6 @! z4 d7 a! \: ]$ b- N/ h require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';& V4 b' O6 o$ v4 Z2 ^) z  ?
替换
9 W: |/ D, k2 D# p' Y$ `6 f require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';  N2 @+ p: \. M0 V% B/ t& u8 c( i, W
0 k' B# Q* m) h) ~& W* r
回复

使用道具 举报

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

本版积分规则

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