我试图让我的登录会话持续更长时间,这样人们就不会过早地退出我的网站。例如,由于 php 使他们的 cookie 过期,发表了一篇博客文章并在提交时丢失了它。
理想情况下,我想让他们说一个 2 小时的会话,他们不会被注销,每次加载页面时都会刷新(下面的代码片段在每个安全页面的标题之前)
这就是我正在尝试的,但它出现了 setcookie() 的错误,说有一个被零除?我在这里做错了什么?
//How long sessions last
$hours = 2;
// php.ini setting required for session timeout.
ini_set('session.gc_maxlifetime',$hours*60*60);
ini_set('session.gc_probability',1);
ini_set('session.gc_divisor',1);
//Set the session parameters and start session
$sessionCookieExpireTime=$hours*60*60;
session_set_cookie_params($sessionCookieExpireTime);
session_start();
// Reset the expiration time upon page load
if (isset($_COOKIE[session_name()]))
{
setcookie(session_name(), $_COOKIE[session_name()], time() + $sessionCookieExpireTime, "/");
}
编辑:现在工作的问题是非标准引号和撇号。以防万一有人复制此代码并使用它。上面的代码现在可以工作了,谢谢!