会话未被保存


Sessions are not being saved

我写了这个脚本。它正在工作,但当我离开页面或返回页面时,会话不会被保存。我做错了什么?

login.php

<?php
session_start();
require 'classes.php';
//if user is not yet authorized
if ($_SESSION['user']->iduser == null) {
    $dbhandle = mysql_connect($hst, $usr, $pass);
    if (!$dbhandle) {
        die('Could not connect: ' . mysql_error());
    }
    $selected = mysql_select_db($dbName, $dbhandle)
            or die("Could not select the database");
    $result = mysql_query(" query ");
    $resultArray = mysql_fetch_array($result);
    $num_rows = mysql_num_rows($result); //count how many rows returned
    //if 0 rows returned, then login was failed
    if ($num_rows == 0) {
        die('Error! Access denied. Incorrect username or password.');
    } else { //if username and password match
        $_SESSION['user'] = new user();
        $_SESSION['user']->iduser = $resultArray{'iduser'};
        $_SESSION['user']->fname = $resultArray{'fname'};
        echo 'Dear ' . $_SESSION['user']->fname . ', you succesfully logged in!';
    }
    //if user is already logged in
} else {
    echo 'You already logged in!<br>Your email is: ';
}
?>

类用户

<?php
class user {
    public $iduser = null;
    public $fname = null;
    public $lname = null;
    public $email = null;
    public $password = null;
    public $permission = null;
}
?>

在会话开始之前,您需要"require(classes.php)"。

(简单答案:)

原因:当您调用session_start时,会话被解码。要使对象正确地未序列化,则必须已经定义了类。呃,你需要在session_start之前定义类——交换这两行就可以了

http://php.net/manual/en/oop4.serialization.php