我遇到会话变量在大约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。
有什么想法吗?
答案 0 :(得分:1)
apache用户是否有可能无法在/ tmp目录中写入,并且该会话仅在该时间段内在ram中处于活动状态。一旦从ram中删除,它将默认为文件,由于权限从未被写入?
答案 1 :(得分:0)
事实证明,问题是php.ini在运行时没有被.htaccess或ini_set中的设置正确覆盖,即使ini_get将值显示为被覆盖。原因尚不清楚,但工作方法是简单地更改php.ini中的session.gc_maxlifetime。