0

我试图让我的登录会话持续更长时间,这样人们就不会过早地退出我的网站。例如,由于 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, "/");
}

编辑:现在工作的问题是非标准引号和撇号。以防万一有人复制此代码并使用它。上面的代码现在可以工作了,谢谢!

4

1 回答 1

1

如果您愿意,可以在 cookie 过期时添加:

time()+60*60*24*30

这就像说 cookie 在 60 秒、60 分钟、24 小时等后过期。您还应该在此处查看有关 cookie 的教程:http: //www.w3schools.com/php/php_cookies.asp

于 2013-04-28T16:43:53.110 回答