自定义会话处理程序不起作用

时间:2012-10-08 11:38:42

标签: php session

有人可以帮助我让自定义会话处理程序工作吗?

这似乎有一半工作,在某些页面上它会将会话写入数据库,但在其他页面上写入没有数据的会话。此外,print_r($ _ SESSION)不再显示任何会话变量。

数据库表:

id - varchar(32 - NULL No - Default None - Primary Key
access - int(10) - unsigned - NULL Yes - Default NULL
data - text - NULL Yes - Default NULL

在前端控制器(定制框架)

require_once('../application/models/sessionfn.php');

session_set_save_handler('_open','_close','_read','_write','_destroy','_clean');
session_start(); 

在sessionfn.php中

function _open()
{
    $config = Configuration::getInstance();
    $host=$config->get("dbhost");
    $dbname=$config->get("db");

    $user=$config->get("dbuser");
    $pass=$config->get("dbpass");

    $dbh = new PDO("mysql:host=$host;dbname=$dbname",$user,$pass); 
}   

function _close()
{
    $dbh = null;
}

function _read($id)
{
    $config = Configuration::getInstance();
    $host=$config->get("dbhost");
    $dbname=$config->get("db");
    $user=$config->get("dbuser");
    $pass=$config->get("dbpass");

    $dbh = new PDO("mysql:host=$host;dbname=$dbname",$user,$pass);
    $sth = $dbh->prepare("SELECT data FROM sessions WHERE id = '$id'");
    $sth->execute();
}

function _write($id, $data)
{
    $config = Configuration::getInstance();
    $host=$config->get("dbhost");
    $dbname=$config->get("db");
    $user=$config->get("dbuser");
    $pass=$config->get("dbpass");

    $dbh = new PDO("mysql:host=$host;dbname=$dbname",$user,$pass);
    $access = time();
    $sth = $dbh->prepare("REPLACE INTO sessions VALUES ('$id', '$access', '$data')");
    $sth->execute();
}

function _destroy($id)
{   
    $config = Configuration::getInstance();
    $host=$config->get("dbhost");
    $dbname=$config->get("db");
    $user=$config->get("dbuser");
    $pass=$config->get("dbpass");

    $dbh = new PDO("mysql:host=$host;dbname=$dbname",$user,$pass);
    $sth = $dbh->prepare("DELETE FROM sessions WHERE id = '$id'");
    $sth->execute();
}

function _clean($max)
{
$config = Configuration::getInstance();
$host=$config->get("dbhost");
    $dbname=$config->get("db");
    $user=$config->get("dbuser");
    $pass=$config->get("dbpass");

    $dbh = new PDO("mysql:host=$host;dbname=$dbname",$user,$pass);
    $old = time() - $max;
    $sth = $dbh->prepare("DELETE FROM sessions WHERE  access < '$old'");
    $sth->execute();
}

1 个答案:

答案 0 :(得分:0)

当我没有亲自动手时,很难调试你的代码。 : - )

但这可能会有所帮助:如何调试自己的sessionhandler?

设置一个可以将输出写入文件的系统。 使用自己的会话处理程序时,不会显示任何错误。

所以在sessionfn.php中添加一个函数:writeToLog($ someStr),写入你自己的一些customlog文件。添加时间戳。附加到现有文件。

现在您可以检查功能调用的所有返回值。

只需清空日志文件,然后开始测试。在每个步骤中检查日志文件。

设置并不多,你可以看到所有问题。