为mybb中的所有用户返回相同的uid和电子邮件

时间:2013-05-20 07:39:08

标签: php database mybb

嗨我有一个类登录用于从外部脚本检查MYBB的用户名和密码它似乎工作但有小问题。对于不同的用户,结果会为所有用户返回相同的uid和电子邮件(mybb_users表中的第一个uid和电子邮件)。请求如何解决这个问题。谢谢你的帮助。

class Login
{
    function CheckLogin( $username, $password )
    {           

$MySQL_Host = "localhost";
$MySQL_User = "root";
$MySQL_Pass = "";
$MySQL_DB = "";
$tbl_name = "";

    // Connect to server and select databse.
     mysql_connect("$MySQL_Host", "$MySQL_User", "$MySQL_Pass") or die(mysql_error());
    // echo "Connected to MySQL<br />";
     mysql_select_db("$MySQL_DB") or die(mysql_error());
    // echo "Connected to Database<br />";

        $sql="SELECT * FROM $tbl_name WHERE username='$username'";
        $result=mysql_query($sql);          

        if( $result == false )
            return false;
//              fwrite($fh, $result);
//              fclose($fh);


        $count=mysql_num_rows($result);
        // If result matched $username and $password, table row must be 1 row
        if($count==1){
            $row = mysql_fetch_assoc($result);
            global $mybb;
            if (md5(md5($row['salt']).md5($password)) == $row['password']){
            return array( 'uid' =>  $mybb->user['uid'] ,
                          'mail' => $mybb->user[ 'email' ],
                          'user' => $username
                        );
            }
        }
    }
}

1 个答案:

答案 0 :(得分:2)

更改您的脚本,如下所示并尝试。

return array( 'uid'  => $row['uid'] ,
              'mail' => $row['email'],
              'user' => $username
            );

我认为这会奏效。