中国网络渗透测试联盟
标题:
织梦(Dedecms)V5.X 本地文件包含漏洞
[打印本页]
作者:
admin
时间:
2013-4-4 17:36
标题:
织梦(Dedecms)V5.X 本地文件包含漏洞
漏洞版本:
8 j3 b( `% P2 [1 @1 _
DedeCms 5.x漏洞描述:
) t, j1 Y3 V1 ?9 y, O* r
DedeCms是免费的PHP网站内容管理系统。
3 l) }+ ~' j4 Q! O, q
& U5 L8 M+ X" N1 h4 V
plus/carbuyaction.php里没有对变量进行严格的过滤
. q/ i4 j5 }+ r) M
" Y: [* k3 j. _; g+ ?" k* M
出现漏洞的两个文件为:
4 |# Z3 w* t( l; u/ }% m+ K
Include/payment/alipay.php
/ w3 K9 s) Y+ T
Include/payment/yeepay.php
' s3 L+ A( o( w) ?2 W' V) L' ^0 ^, z
漏洞均出现在respond方法里
1 D1 A9 u: o" h% w
& S. X8 {3 i, W8 l, s1 ?: C$ Y) w
Include/payment/alipay.php
1 ]7 h5 ^8 S2 d9 z* a
......function respond(){if (!empty($_POST)){foreach($_POST as $key => $data){$_GET[$key] = $data;}}/* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';......
" O) {. t% K4 D' l- r& n, j, p
3 L+ l- z1 l: s* Q
大概在133行左右,$_GET[‘code’]没有经过任何判断和过滤。
; C8 T% F7 S- X I/ ~' a
Include/payment/yeepay.php
A4 }6 M# z' c5 b4 f" D1 ~
......function respond(){ /* 引入配置文件 */require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php'; $p1_MerId = trim($payment['yp_account']);$merchantKey = trim($payment['yp_key']);......
" v0 ?- q- Q! i: x8 }: _
+ K4 M8 |5 r( B2 m2 f( u
大概在145行左右,$_REQUEST['code']没有经过任何判断和过滤。<* 参考
% j |0 o" n$ i3 x4 W
http://bugscan.net/manage/node/83
n7 i; Y. W' q# N @
http://www.cnseay.com/2515/
! I) s' O" T# B. V! A! k
*>
/ C/ j5 \% D" u
测试方法:
9 A* ^! B# o0 r' h) v/ V
1.
http://www.dedecms.com/plus/carb ... amp;code=../../tags
上面的Exp是包含根目录下的tags.php文件包含其他后缀请自行构造截断, 使用exp测试时须要自己添加一个code等于alipay或yeepay的cookie
! K5 ?/ \' ]5 F6 Y
2.由于bank和cod这两个文件并没有respond方法,所以如果code等于bank或者cod时将会暴错泄露路径
9 y2 k- E5 A; }) |4 p$ e$ a
修复方法:
6 M1 A6 u2 @! X6 O$ [7 ]0 n7 D+ w9 E
目前厂商还没有提供补丁或者升级程序,我们建议使用此软件的用户随时关注厂商的主页以获取最新版本:
- S0 V. ^$ r' y
http://www.dedecms.com/products/dedecms/
8 `" e5 d; V" c$ p8 t
2 i0 L( w) c Y; h
临时修复:
0 l6 ~5 y8 h) m2 q$ ^7 E
1)Include/payment/alipay.php
1 |1 J. c% N1 r( M8 m
大概133行左右
_, W) z6 r' u, M y
require_once DEDEDATA.'/payment/'.$_GET['code'].'.php';
- q; @, K# E& t
替换
2 V1 v G+ ]7 A. {# E- \4 ~
require_once DEDEDATA.'/payment/'.basename($_GET['code']).'.php';
7 Y p1 }: R- L2 t' T3 P
2) Include/payment/yeepay.php
, \, D+ g$ k2 o1 q& ~( {
大概在145行左右
: C4 D8 q- {/ v7 z- t ^2 b
require_once DEDEDATA.'/payment/'.$_REQUEST['code'].'.php';
6 Z9 r; X. \. N7 r/ P# w6 l; q- l
替换
" L0 G8 b' \" Z' Q
require_once DEDEDATA.'/payment/'.basename($_REQUEST['code']).'.php';
! f/ d6 D! N+ x
5 b; S0 y, y+ |( l
欢迎光临 中国网络渗透测试联盟 (https://cobjon.com/)
Powered by Discuz! X3.2