PHP会话没有设置第一次

问题描述:

我有一个奇怪的问题。访问者第一次访问该网站时,我设置了会话的任何内容,但它并没有固定。第二次和所有下面的时间我试图设置一些它坚持。在最初的尝试之后,我可以销毁会话并设置一些东西,并坚持下去。它只是保存某些东西的初始尝试失败。我正在努力为$_SESSION['uid'] = $row["Id"];节省点东西。我知道$row["Id"]是有效的,并保存数据(我呼应它)。PHP会话没有设置第一次

我没有使用标准会话。我将会话保存到数据库中。我的课程是在下面。有什么我失踪或做错了解释这种行为?

更新

好吧,我测试了它自己的会话类,它似乎是工作: - /但是,当我在较大的应用程序_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(); 

我猜我有点白痴。我打电话给session_destroy()而不是session_unset(),以清除身份验证脚本顶部的内容。该课程正常工作。

我认为你应该在定义你的类之后开始一个会话。不在里面。

+0

这似乎没有什么区别。 – Justin808 2012-03-05 23:27:42