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