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

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

[复制链接]
跳转到指定楼层
楼主
发表于 2013-4-4 17:36:50 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
漏洞版本:% L1 D3 l, K. z2 g" Y0 D
DedeCms 5.x漏洞描述:
1 c; p; @7 d$ u! |- d( p/ f4 FDedeCms是免费的PHP网站内容管理系统。" r& P# P; W6 b) I  U" L
/ ^- z0 h# m) ?
plus/carbuyaction.php里没有对变量进行严格的过滤8 q5 B8 u& s9 U# S$ ~; |) U
% B, ?9 g2 N- H% i
出现漏洞的两个文件为:- I' G0 x! G6 M$ b
Include/payment/alipay.php
8 B; i* r: _4 u& \Include/payment/yeepay.php
' a/ l/ f- |, M9 E+ X) u5 I漏洞均出现在respond方法里+ n: ]4 S& a1 @/ R* D1 t. ^
  k* Z+ g; c) x# E; \' a
Include/payment/alipay.php
( J- y$ I4 }6 L; f6 |2 J/ Z, J3 o......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
, Q- r- L% |. }8 R; }% ]                       
4 v; C' [; I" ~0 j  d大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。/ H& \' }) V  z( n" H7 u% b
Include/payment/yeepay.php
# k0 X7 B8 e1 q; ~3 e  f  C......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......9 T, `- h# W4 H# Y& W1 s
                       
/ Q9 Z/ B# w* u! g) H3 g* B# C大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考+ b0 j% U; D1 j* U0 v! P- o  `( i6 Z
http://bugscan.net/manage/node/83
, n- N& T* O4 r: ^http://www.cnseay.com/2515/
6 b( w0 i0 N* @: L$ @  y6 f*>+ \" B% i# _# d* r% ~3 E
测试方法:+ ]% t; r$ ]5 J: O1 L/ _
1.http://www.dedecms.com/plus/carb ... amp;code=../../tags 上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
- Y& J' z; j" S+ a3 |5 L2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
+ [1 @1 h9 i5 F4 z6 q7 _修复方法:
  O# D4 Z7 {# D目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:2 I8 R8 q( w0 l
http://www.dedecms.com/products/dedecms/
3 y; B, E0 p4 \  y4 F- P* Y+ |- E% J, a, I; H. o* a7 C
临时修复: ; o, i* j% g1 M  a) v8 K/ V
1)Include/payment/alipay.php6 u0 v1 n$ S% T/ O" o
  大概133行左右
7 S$ Y- B% Y4 x- q/ j0 r9 t4 c& `$ c  require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
+ d  r# v/ ]* t. g2 S0 U3 m3 m" \替换/ @" Q: |: f3 Q! Z( {* _7 i2 o
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
; {2 P  ?& W! A# ]) Q2) Include/payment/yeepay.php% C- q* S2 V8 c7 |) T
大概在145行左右! h: T$ T" K6 K# K
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
( I# i8 X0 r5 i 替换
2 L" f& G6 Y3 Q% P require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';4 {2 V0 I& P; i

) g! K6 |2 J7 z; _* S
回复

使用道具 举报

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

本版积分规则

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