查看关于设置cookie的php文档,我看到我可以为cookie设置过期日期。您可以将cookie设置为在浏览器会话结束时过期,或者在将来的某个时间过期,但我不知道如何将cookie设置为永不过期。这可能吗?这是如何实现的?
当前回答
设定遥远未来的绝对时间:
setcookie("CookieName", "CookieValue", 2147483647);
使用绝对时间比按照公认答案中建议的相对于当前计算时间要好。
与32位系统兼容的最大值为:
2147483647 = 2^31 = ~year 2038
其他回答
我不确定,但cookie不是在浏览器关闭时删除的吗?我以某种方式做了一个永不过期的cookie和chrome识别过期日期为“在浏览器关闭”…
我的特权阻止我对第一篇文章发表评论,所以它必须在这里。
从当前日期提前20年设置时,应该考虑到2038 unix错误,这是上面建议的正确答案。
你的cookie在2018年1月19日(20年后)可能会遇到2038问题,这取决于你最终运行的浏览器和或版本。
设定遥远未来的绝对时间:
setcookie("CookieName", "CookieValue", 2147483647);
使用绝对时间比按照公认答案中建议的相对于当前计算时间要好。
与32位系统兼容的最大值为:
2147483647 = 2^31 = ~year 2038
虽然这是不可能的,但你可以做一些类似谷歌所做的事情,将你的cookie设置为2038年1月17日或同样遥远的时间。
实际上,你最好将你的cookie设置为10年或60*60*24*365*10年,这应该比你的cookie所使用的大多数机器的寿命都长。
根据cookie规范,所有cookie都会过期,因此这不是PHP的限制。
使用一个遥远的未来日期。例如,设置一个十年过期的cookie:
setcookie(
"CookieName",
"CookieValue",
time() + (10 * 365 * 24 * 60 * 60)
);
注意,如果您在32位PHP中设置了超过2038的日期,则该数字将被换行,您将得到一个立即过期的cookie。
推荐文章
- 在PHP单元测试执行期间,如何在CLI中输出?
- 在PHP中使用heredoc的优势是什么?
- PHP中的echo, print和print_r有什么区别?
- HttpOnly cookie如何与AJAX请求一起工作?
- 如何将XML转换成PHP数组?
- 如何将对象转换为数组?
- 从IP地址获取位置
- 获取数组值的键名
- HTTPS和SSL3_GET_SERVER_CERTIFICATE:证书验证失败,CA is OK
- PHP -获取bool值,当为false时返回false
- 在foreach中通过引用传递
- 如何触发命令行PHP脚本的XDebug分析器?
- 如何找出如果你使用HTTPS没有$_SERVER['HTTPS']
- 更好的方法检查变量为null或空字符串?
- 当使用Composer的开发/生产开关时,如何正确部署?