Я пытаюсь написать пользовательский сеанс, сохраняемый в PHP. Но по какой-то причине вызывается только моя функция чтения сеанса, а не функция записи сеанса. Таким образом, сеанс не сохраняется. Если я переключаюсь обратно на обработчик сеанса по умолчанию (файл), все работает. Если я добавлю session_write_close()
в конце тестового скрипта - все работает. Но в руководстве по PHP явно говорится, что вам не нужно явно вызывать session_write_close()
, потому что он вызывается автоматически в конце скрипта. И я не хочу ставить session_write_close () на каждой возможной точке выхода в моем существующем приложении!
Вот код, который иллюстрирует проблему. Я запускаю его на WinXP SP3 + Apache 2.2.9 + PHP 5.2.6. Файл журнала содержит записи только для s_open()
и s_read()
.
<?php
function logger($str)
{
file_put_contents('session_log.txt', date('Y-m-d h:i:s') . " $str\r\n", FILE_APPEND);
}
function s_open()
{
logger('s_open');
return true;
}
function s_close()
{
logger('s_close');
return true;
}
function s_read()
{
logger('s_read');
return @file_get_contents('session.txt');
}
function s_write($id, $data)
{
logger("s_write: $id - $data");
file_put_contents('session.txt', $data);
return true;
}
function s_destroy()
{
logger('s_destroy');
return true;
}
function s_gc()
{
logger('s_gc');
return true;
}
session_set_save_handler('s_open', 's_close', 's_read', 's_write', 's_destroy', 's_gc');
session_start();
if ( isset($_SESSION['time']) )
echo 'Session time: ' . date('Y-m-d h:i:s', $_SESSION['time']);
else
echo 'Session empty';
echo '<br>';
echo 'Session ID: ' . session_id();
$_SESSION['time'] = time();
?>