调试致命错误

时间:2015-12-23 03:10:02

标签: php pdo

我试图使用PDO创建一个登录页面,但我收到此错误,我在这里检查了有关此错误的类似查询,但它们似乎与我的不同

注意:未定义的变量:第5行的C:\ xampp \ htdocs \ soft \ index.php中的用户

致命错误:在第5行的C:\ xampp \ htdocs \ soft \ index.php中调用null成员函数is_loggedin()

是什么导致致命错误,我该如何解决这个问题,因为根据我自己的理解,代码似乎没问题。 这是我的登录页面代码

<?php
require_once 'dbconfig.php';

if($user->is_loggedin()!="")
{
    $user->redirect('home.php');
}

if(isset($_POST['btn-login']))
{
    $uname = $_POST['txt_uname_email'];
    $umail = $_POST['txt_uname_email'];
    $upass = $_POST['txt_password'];

    if($user->login($uname,$umail,$upass))
    {
        $user->redirect('home.php');
    }
    else
    {
        $error = "Wrong Details !";
    }   
}
?>

这是登录功能

public function is_loggedin()
{
    global $db;

    if(isset($_SESSION['user_session']))
    {
        return true;
    }
}

这是我的用户类

<?php
class USER
{
    private $db;

    function __construct($DB_con)
    {
        $this->db = $DB_con;
    }

    public function register($fname,$lname,$uname,$umail,$upass)
    {
        try
        {
            $new_password = MD5($upass);

            $stmt = $this->db->prepare("INSERT INTO users(user_name,user_email,user_pass) 
                                                       VALUES(:uname, :umail, :upass)");

            $stmt->bindparam(":uname", $uname);
            $stmt->bindparam(":umail", $umail);
            $stmt->bindparam(":upass", $new_password);                                        

            $stmt->execute();   

            return $stmt;   
        }
        catch(PDOException $e)
        {
            echo $e->getMessage();
        }               
    }

    public function login($uname,$umail,$upass)
    {
        try
        {
            $stmt = $this->db->prepare("SELECT * FROM users WHERE user_name=:uname OR user_email=:umail LIMIT 1");
            $stmt->execute(array(':uname'=>$uname, ':umail'=>$umail));
            $userRow=$stmt->fetch(PDO::FETCH_ASSOC);
            if($stmt->rowCount() > 0)
            {
                if($userRow['user_pass']==MD5($upass))
                {
                    $_SESSION['user_session'] = $userRow['user_id'];
                    return true;
                }
                else
                {
                    return false;
                }
            }
        }
        catch(PDOException $e)
        {
            echo $e->getMessage();
        }
    }

    public function is_loggedin()
    {
        global $db;

        if(isset($_SESSION['user_session']))
        {
            return true;
        }
    }

    public function redirect($url)
    {
        header("Location: $url");
    }

    public function logout()
    {
        session_destroy();
        unset($_SESSION['user_session']);
        return true;
    }
}
?>

我只是一个新手,我想知道我做错了多少谢谢

2 个答案:

答案 0 :(得分:0)

你还没有宣布用户是什么。

有些人通过启动会话并将其包含在下一页的最顶层来执行此操作,因此您可以调用函数来查看用户是否已登录。

无论哪种方式,我都没有看到与您声明$user变量相关的任何内容(包括文件)。

答案 1 :(得分:0)

检查dbconfig.php文件,确保您拥有以下代码

include_once 'class.user.php';
$user = new USER($DB_con);

我认为你需要声明你的用户。