某变量未初始化导致服务器设置register_global=On时会员可以随意修改自己的member信息。
7 @" w/ R% ~) [) L
4 k1 Q) ~. } l" M" g6 u7 n3 X. h: I. }由于需要register_global=On支持,影响有限。。漏洞涉及到会员可以修改自己的余额导致网站可能产生严重后果因此漏洞等级设为高。0 e8 P3 X/ j% p' c7 F
详细说明:修改用户密码的account_manage_password函数未对$updateinfo初始化,导致可以提交& l! z8 V4 B& a3 o
updateinfo[amount]这样的数组随意修改自己的余额、点数、会员组、VIP等一切存放在member表的信息# u8 W9 n% l8 U4 z
文件: \phpcms\modules\member\index.php+ S9 @1 B7 F% K, A+ Y) o s
3 x3 K$ u( X, s8 {1 M) |
约435行:
- ~4 \% x) A9 e4 f$newpassword = password($_POST['info']['newpassword'], $this->memberinfo['encrypt']);
/ _' j6 p* @3 R( ~$ s* y4 X; K$updateinfo['password'] = $newpassword;5 {7 ^' G+ |" s# R
$this->db->update($updateinfo, array('userid'=>$this->memberinfo['userid']));
8 T& ]; w6 w+ o! ?6 c4 u漏洞证明:文件: \phpcms\modules\member\index.php4 r. `# K h. O
; L7 n0 n2 \. e! y( d* x8 `. U& J
约435行:" h' M) {& u7 J
$newpassword = password($_POST['info']['newpassword'], $this->memberinfo['encrypt']);
! d: S6 W& }2 J) ~$updateinfo['password'] = $newpassword;+ n! b. [0 U# V, S7 i0 `1 D
$this->db->update($updateinfo, array('userid'=>$this->memberinfo['userid']));) r7 m$ ^4 [, B- q
0 y+ c/ P4 n1 w% S$ ?9 e) F, J修复方案:
. G7 [+ R! r9 w/ C5 A2 ~+ p/ [0 G- M* h) n L* p1 N) R/ s
$updateinfo = array();
k1 p( C* h9 e0 E3 G
. a$ u$ H1 l* _1 `- X+ ~- U/ B7 N |