phpcms php sql修改密码,PhpcmsV9 任意用户密码修改逻辑漏洞 | CN-SEC 中文网

摘要

其实我在发第一个漏洞的时候,就看到了

WooYun: PhpcmsV9 SQL注射 2013年贺岁第一发

提到的通行证的代码:

parse_str(sys_auth($_POST['data'], 'DECODE', $this->applist[$this->appid]['authkey']), $this->data);

其实我在发第一个漏洞的时候,就看到了

WooYun: PhpcmsV9 SQL注射 2013年贺岁第一发

提到的通行证的代码:

parse_str(sys_auth($_POST['data'], 'DECODE', $this->applist[$this->appid]['authkey']), $this->data);

在phpsso_server/phpcms/modules/phpsso/classes/phpsso.class.php中。

我把它留给了你们。

不知道你们发现了它没有。

我们知道parse_str类似将http请求转换成php变量的函数,所以,也像http请求在php的环境下一样,如果提交?a=sss&a=aaa,那么a的结果会是aaa,不是sss。

所以我们知道这个函数有一个问题了,如果后面提交一个内容,它会覆盖前面的。

也就是

username=zhangsan&username=lisi的话,那么用户名就不是zhangsan了。

要构造这样的请求,我们还是要回到通行证的client看看,我们有没有这样的机会。

其实我们有这样的机会,看看代码,如下:

[php]public function auth_data($data) {

$s = $sep = '';

foreach($data as $k => $v) {

if(is_array($v)) {

$s2 = $sep2 = '';

foreach($v as $k2 => $v2) {

$s2 .= "$sep2{$k}[$k2]=".$this->_ps_stripslashes($v2);

$sep2 = '&';

}

$s .= $sep.$s2;

} else {

$s .= "$sep$k=".$this->_ps_stripslashes($v);

}

$sep = '&';

}

$auth_s = 'v='.$this->ps_vsersion.'&appid='.APPID.'&data='.urlencode($this->sys_auth($s));

return $auth_s;

}

[/php]

可能我没说明白,对,传递进来的数组的key是可控的。如果我的key里包含[]&这样三个字符的话,那么我就能重写这样的东西。

举个例子

$a[aaa=a&bbb] = 'a';

会变成aaa=a&bbb=a

明白了么,对,就是通过没有注意到的key,我们可以构造出多余的参数来。

这个时候,我们可以再去看一个函数。

就在这个文件内:

[php]

public function ps_member_edit($username, $email, $password='', $newpassword='', $uid='', $random='') {

if($email && !$this->_is_email($email)) {

return -4;

}

return $this->_ps_send('edit', array('username'=>$username, 'password'=>$password, 'newpassword'=>$newpassword, 'email'=>$email, 'uid'=>$uid, 'random'=>$random));

}

[/php]

这是向通行证发了这样一个请求。

我们再跟到通信证代码里去看看,就会有所发现。

public function edit() {

//能省就省,太长了不是吗?

if($this->username) {

//如果提交了用户名,则按照用户名修改记录,反之,按照uid来修改记录。

$res = $this->db->update($data, array('username'=>$this->username));

} else {

file_put_contents('typeb.txt',print_r($data,1).$this->uid);

$res = $this->db->update($data, array('uid'=>$this->uid));

}

好,我们知道了,如果提交了用户名,就会按照用户名来修改记录,不然就按照uid,我们看看函数结构:

public function ps_member_edit($username, $email, $password='', $newpassword='', $uid='', $random='')

很好,uid要是无法控制的话,后面只剩下一个random了,但是username就在第一个,只要email,password,newpassword,有任何一个可以控制,就可以修改密码了。

我当然找到了:

phpcms9/phpcms/modules/member/index.php

$res = $this->client->ps_member_edit('', $email, $_POST['info']['password'], $_POST['info']['newpassword'], $this->memberinfo['phpssouid'], $this->memberinfo['encrypt']);

然后就没有然后了。

[php]

邮箱:

原密码:

新密码:

[/php]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值