PHP-是否可以为会话变量设置无限制的Cookie时间?
作者:互联网
如何为会话的Cookie设置无限时间?我在下面尝试了以下方法,但是一天后仍在会话中得到未定义的索引通知:
setcookie('idcourse', 'CourseID', 9999999999);
setcookie('namecourse', 'CourseName', 9999999999);
setcookie('id', 'ID', 9999999999);
if (isset($_POST['idcourse'])) {
$_SESSION['idcourse'] = $_POST['idcourse'];
}
if (isset($_POST['namecourse'])) {
$_SESSION['namecourse'] = $_POST['namecourse'];
}
if (isset($_POST['id'])) {
$_SESSION['id'] = $_POST['id'];
}
解决方法:
您必须添加一个有效期,否则Cookie会像会话一样工作,并在您离开网站时失效,
您正在做的事情几乎是正确的,但是您需要对其稍作更改;
您要设置过期9999999999(将来需要指定UNIX TIMESTAMP),所以我使用以下命令:
$inTwoMonths = 60 * 60 * 24 * 60 + time();
setcookie('idcourse', 'CourseID', $inTwoMonths );
setcookie('namecourse', 'CourseName', $inTwoMonths );
setcookie('id', 'ID', $inTwoMonths );
会使Cookie在2个月后过期,您可以相应地对此进行递增.
标签:cookies,session-cookies,session,php 来源: https://codeday.me/bug/20191031/1979318.html