大约30分钟后,PHP会话变量为空

时间:2013-04-03 16:18:32

标签: php linux session variables

我遇到会话变量在大约35-40分钟后变为空的问题。但是,会话ID似乎仍然显示为有效(和之前的数字相同)。

我创建了一些测试代码,用于读取和显示会话变量,然后在越来越多的秒后重新加载页面。它一直工作到2400秒,此时变量在下一次显示时为空。换句话说,它在刷新之间等待2400秒时始终为null。我已经将.htaccess中的session.gc_maxlifetime设置为7800(并且它显然已设置,因为它使用ini_get读取为7800)。

我要么缺少一些明显的东西,要么在这里有一些严重的陌生感。这让我疯了。

这是在带有WHM的Linux VPS上。

创建测试会话的代码:

<?php
    // start session
    session_start();

    // set session value
    $_SESSION["session_memberid"] = 1234567;
    $_SESSION["session_refresh"] = 2000;

    // write file, close
    session_write_close();

    // display confirmation
    echo json_encode(array(
        '$_SESSION["session_memberid"]' => $_SESSION["session_memberid"],
        'session_id' => session_id(),
        'maxlifetime' => ini_get('session.gc_maxlifetime')
    ));
?>

读取会话的代码(自动重新加载):

<?php
// start session
session_start();

// get session id
$session_id = session_id();

// get stored memberid
$member_id = $_SESSION['session_memberid'];
$_SESSION['session_memberid'] = $member_id;

// get last activity
$lastactivity = $_SESSION["last_activity"];

// increasing refresh time
$refresh = $_SESSION["session_refresh"];
$_SESSION["session_refresh"] = $refresh + 100;

// update time
$_SESSION["last_activity"] = time();

// write file, close
session_write_close();

...
(code to display and refresh variables)

有效读取时的输出:

{"memberid":1234567,"session_id":"c9d20d4992f184f29b259ef5ccab275f","sessionpath":"\/tmp","maxlifetime":"7800","sessioncookiepath":"\/","sessioncookielifetime":"0","referrer":"","autostart":"0","cache":false,"time":1365004882,"cookie":{"lifetime":0,"path":"\/","domain":"","secure":false,"httponly":false},"refresh":2400}

无效读取时的输出显示memberid(我们需要的变量),time(last_activity)和刷新时间为null。

有什么想法吗?

2 个答案:

答案 0 :(得分:1)

apache用户是否有可能无法在/ tmp目录中写入,并且该会话仅在该时间段内在ram中处于活动状态。一旦从ram中删除,它将默认为文件,由于权限从未被写入?

答案 1 :(得分:0)

事实证明,问题是php.ini在运行时没有被.htaccess或ini_set中的设置正确覆盖,即使ini_get将值显示为被覆盖。原因尚不清楚,但工作方法是简单地更改php.ini中的session.gc_maxlifetime。