我有一个奇怪的问题。访问者第一次来到网站,我设置的任何东西都是会话,它不会坚持。第二次以及以下所有次我尝试设置它坚持的东西。在最初的尝试后,我可以破坏会话并设置一些东西,它会坚持下去。它只是最初尝试保存的东西失败了。我正在尝试使用$_SESSION['uid'] = $row["Id"];
将某些内容保存到会话中。我知道$row["Id"]
是有效的并保存数据(我回应它)。
我没有使用标准会话。我将会话保存到数据库中。我的会话课程如下。解释这种行为是否有任何我遗漏或做错的事情?
更新:
我自己测试了会话类,它似乎正在工作: - /但是当我在更大的应用程序_write
中使用它时,永远不会被调用,尽管__destruct
会被调用。知道为什么会这样吗?
<?php
include_once('db.php');
class PDOSession
{
protected $pdo;
protected $table = 'SessionData';
public function __construct()
{
// Get a database connection
$db = new PDOConnectionFactory();
$this->pdo = $db->getConnection(true);
// Start session
session_set_save_handler(array($this, '_open'),
array($this, '_close'),
array($this, '_read'),
array($this, '_write'),
array($this, '_destroy'),
array($this, '_gc'));
session_start();
}
public function __destruct()
{
session_write_close();
}
protected function fetchSession($id)
{
$stmt = $this->pdo->prepare('SELECT id, data FROM '.$this->table.' WHERE id = :id AND unixtime > :unixtime');
$stmt->execute(array(':id' => $id, ':unixtime' => (time() - (int)ini_get('session.gc_maxlifetime'))));
$sessions = $stmt->fetchAll();
return empty($sessions) ? false : $sessions[0];
}
public function _open($savePath, $sessionName)
{
return true;
}
public function _close()
{
return true;
}
public function _read($id)
{
$session = $this->fetchSession($id);
return ($session === false) ? false : $session['data'];
}
public function _write($id, $sessionData)
{
$session = $this->fetchSession($id);
if($session === false) {
$stmt = $this->pdo->prepare('INSERT INTO '.$this->table.' (id, data, unixtime) VALUES (:id, :data, :time)');
} else {
$stmt = $this->pdo->prepare('UPDATE '.$this->table.' SET data = :data, unixtime = :time WHERE id = :id');
}
$stmt->execute(array(
':id' => $id,
':data' => $sessionData,
':time' => time()
));
}
public function _destroy($id)
{
$stmt = $this->pdo->prepare('DELETE FROM '.$this->table.' WHERE id = :id');
$stmt->execute(array(':id' => $id));
}
public function _gc($maxlifetime)
{
$stmt = $this->pdo->prepare('DELETE FROM '.$this->table.' WHERE unixtime < :time');
$stmt->execute(array(':time' => (time() - (int) $maxlifetime)));
}
}
$newPDOSessionStartHere = new PDOSession();
答案 0 :(得分:1)
session_destroy()
而不是session_unset()
来清除身份验证脚本顶部的内容。这节课很好。
答案 1 :(得分:0)
我认为你应该在定义课程后开始一个课程。不在里面。