我正在设置一个PHP会话,在登录后4小时内有效。但是会话将在四舍五入的时间完全过期(@1 AM,2 AM,3 AM等)
如果在凌晨12点或12点30分登录,会话将在凌晨1点到期。
在共享托管会话的中是否存在默认设置?
我试过更改会话保存路径和会话生命,但没有用。
这是我在登录页面时的代码。
// server should keep session data for AT LEAST 4 hour
ini_set(session.save_path, "/home/web/session");
ini_set('session.gc_maxlifetime', 14400);
session_start();
$_SESSION['login'] = 1;
$_SESSION['sessionid']=session_id();
在其他几页中:
if($_SESSION['login'] == 1 $_SESSION['sessionid']==session_id())
{
echo "you are aleady logged in...";
}
else
{ echo "you are not logged in..." ; //this is occurring exactly every hour
}
你能帮我解决这个问题吗?
发布于 2014-06-10 16:32:24
Session_start()必须先于其他一切。那可能是你的问题。无论如何,这种方式是非常不可靠的,所以最好将您自己的会话超时设置为:
if (isset($_SESSION['LAST_ACTIVITY']) && (time() - $_SESSION['LAST_ACTIVITY'] > 14400)) {
// last request was more than 30 minutes ago
session_unset(); // unset $_SESSION variable for the run-time
session_destroy(); // destroy session data in storage
}
$_SESSION['LAST_ACTIVITY'] = time(); // update last activity time stamp
https://stackoverflow.com/questions/24146276
复制相似问题