-7

错误是:未定义变量:第 24 行 /var/www/index.php 中的 mysqli 致命错误:在第 24 行 /var/www/index.php 中的非对象上调用成员函数 real_escape_string()

连接.php

<?php

/**
* Mysql Connect
*/

class MysqlConnect
{
    private $db_host;
    private $db_usermame;
    private $db_password;
    private $db_database;

    public function __construct($db_host,$db_usermame,$db_password,$db_database)
    {   
        $this->db_host = $db_host;
        $this->db_usermame = $db_usermame;
        $this->db_password = $db_password;
        $this->db_database = $db_database;

        $mysqli = mysqli_connect("$this->db_host", "$this->db_usermame", "$this->db_password", "$this->db_database") or die("Can't connect");
        $mysqli->select_db("$this->db_database") or die("Can't select database");
    }
}

$mysqli = new MysqlConnect('localhost','root','nistor','game');

?>

索引.php

<?php

require_once ('connect.php');

?>

Register

<?php 

/**
* Register
*/


class RegisterUser
{   

    public $username;
    public $password;
    public $email;
    function verify(){
        if (isset($_POST['register'])) {
        return $username = $mysqli->real_escape_string($username);
        var_dump($mysqli); exit;
    }else{
        echo "no";
    }
}

}

$obj = new RegisterUser();
$obj->verify();

?>
<form action="index.php" method="POST">
Username: <input type="text" name="username"><br />
Password: <input type="password" name="password"><br />
E-Mail: <input type="text" name="email"><br />
<input type="submit" name="register" value="Register">
</form>
4

1 回答 1

-1

您的 verify 函数没有名为 的对象$mysqli,它仅存在于您的MysqlConnect类的constructor. 您可以MysqlConnect按如下方式重新调整您的班级。

class MysqlConnect
{
    private $db_host;
    private $db_usermame;
    private $db_password;
    private $db_database;
    private $mysqli;

    public function __construct($db_host,$db_usermame,$db_password,$db_database)
    {   
        $this->db_host = $db_host;
        $this->db_usermame = $db_usermame;
        $this->db_password = $db_password;
        $this->db_database = $db_database;

        $this->mysqli = mysqli_connect("$this->db_host", "$this->db_usermame", "$this->db_password", "$this->db_database") or die("Can't connect");
        $this->mysqli->select_db("$this->db_database") or die("Can't select database");
    }

    public function getMysqli()
    {
        return $this->mysqli;
    }
}

完成此操作后,您可以在驱动程序类中执行类似于以下代码的操作,即registeruser.

class RegisterUser
{   

    public $username;
    public $password;
    public $email;
    function verify(){
        $mysqlcon = new MysqlConnect('localhost','root','nistor','game');
        $mysqli = $mysqlcon->getMysqli();
        if (isset($_POST['register'])) {
        return $username = $mysqli->real_escape_string($username);
        var_dump($mysqli); exit;
    }else{
        echo "no";
    }
}

}
于 2013-07-01T14:00:39.633 回答