首页 > 开发 > PHP > 正文

关于phpwind 5.01-5.3 0day的分析文章

2024-05-04 23:03:42
字体:
来源:转载
供稿:网友
注册会员,创建你的web开发资料库,今天要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')");
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表