有人可以帮助我让自定义会话处理程序工作吗?
这似乎有一半工作,在某些页面上它会将会话写入数据库,但在其他页面上写入没有数据的会话。此外,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();
}
答案 0 :(得分:0)
当我没有亲自动手时,很难调试你的代码。 : - )
但这可能会有所帮助:如何调试自己的sessionhandler?
设置一个可以将输出写入文件的系统。 使用自己的会话处理程序时,不会显示任何错误。
所以在sessionfn.php中添加一个函数:writeToLog($ someStr),写入你自己的一些customlog文件。添加时间戳。附加到现有文件。
现在您可以检查功能调用的所有返回值。
只需清空日志文件,然后开始测试。在每个步骤中检查日志文件。
设置并不多,你可以看到所有问题。