中国网络渗透测试联盟

标题: PHPCMS V9 member表内容随意修改漏洞及修复 [打印本页]

作者: admin    时间: 2012-12-4 11:27
标题: PHPCMS V9 member表内容随意修改漏洞及修复
某变量未初始化导致服务器设置register_global=On时会员可以随意修改自己的member信息。
" \; J. o: D( o0 |8 a9 P
- `9 O9 h+ J1 a+ X6 W2 ?由于需要register_global=On支持,影响有限。。漏洞涉及到会员可以修改自己的余额导致网站可能产生严重后果因此漏洞等级设为高。- l# C! Q! m4 X# I9 \/ v
详细说明:修改用户密码的account_manage_password函数未对$updateinfo初始化,导致可以提交
/ `3 M% u0 M( p& f0 z1 wupdateinfo[amount]这样的数组随意修改自己的余额、点数、会员组、VIP等一切存放在member表的信息
/ W* _0 r1 A3 n' k% k文件: \phpcms\modules\member\index.php  J8 [/ r- `: m2 E0 j! k
6 w/ n$ y. ]( p) o5 J9 |+ C5 V
约435行:
) L/ P- W. ~! G$newpassword = password($_POST['info']['newpassword'], $this->memberinfo['encrypt']);7 Z! Z# e+ Y3 I; b( E
$updateinfo['password'] = $newpassword;
4 ^5 b; D4 P, I4 n$this->db->update($updateinfo, array('userid'=>$this->memberinfo['userid']));
; ^; A/ a' L9 V; d  c  w9 Z漏洞证明:文件: \phpcms\modules\member\index.php
0 R* A: T% E  p9 Y  Q7 H+ `1 ^" T& L3 U1 f* e- Q' Q
约435行:/ |, b7 j& T2 o. p3 P
$newpassword = password($_POST['info']['newpassword'], $this->memberinfo['encrypt']);3 D) N4 p% u' Z  |+ c9 W
$updateinfo['password'] = $newpassword;# Z* ~3 b+ k: A/ u9 Y
$this->db->update($updateinfo, array('userid'=>$this->memberinfo['userid']));
4 @3 l/ K. D7 G
4 }* a. i4 M; z: C8 j" y修复方案:
! V! o. i$ A# o/ l4 ?) Y0 B* w
7 L4 Z: K; \+ p7 O5 l* Y$updateinfo = array();
8 g/ ]: K7 ]; ^9 m: X8 w; f8 a, ]
; p  ^! |5 }6 d$ w  k




欢迎光临 中国网络渗透测试联盟 (https://cobjon.com/) Powered by Discuz! X3.2