查看关于设置cookie的php文档,我看到我可以为cookie设置过期日期。您可以将cookie设置为在浏览器会话结束时过期,或者在将来的某个时间过期,但我不知道如何将cookie设置为永不过期。这可能吗?这是如何实现的?


当前回答

当链接发布时,Chrome cookie最多可以存活400天。Chrome在这个回应的时候是一个大问题,所以我会让一个cookie的过期是在400天或更少。

如果你不想点击链接,它会总结说:

当cookie设置了显式的Expires/Max-Age属性时,该值将被限制在未来不超过400天。在此之前,没有任何限制,而且饼干在未来可能会过期数千年之久。

其他回答

你不应该这样做,这是不可能的,如果你愿意,你可以设置一个更大的值,比如10年以后。

顺便说一句,我从来没有见过有这样要求的饼干:)

最大值:2147483647

setcookie("CookieName", "CookieValue", 2147483647);

为了避免整数溢出,时间戳应该设置为:

2^31 - 1 = 2147483647 = 2038-01-19 04:14:07

设置较高的值可能会在旧浏览器中出现问题。

也可以查看RFC关于cookie的内容:

信息=值 可选的。Max-Age属性的值是delta-seconds, cookie的生存期,以秒为单位,非负十进制 整数。为了正确地处理缓存的cookie,客户端应该 根据年龄计算,计算cookie的年龄 HTTP/1.1规范[RFC2616]中的规则。当年龄是 大于delta-seconds seconds,客户端应该丢弃 饼干。值为0表示cookie应该被丢弃 立即。

和RFC 2616, 14.6年龄:

如果缓存接收到的值大于最大的正数 整数它可以表示,或者它的任何年龄计算 溢出时,它必须传输一个Age报头,其值为 2147483648(2 ^ 31)。

http://www.faqs.org/rfcs/rfc2616.html

设定遥远未来的绝对时间:

setcookie("CookieName", "CookieValue", 2147483647);

使用绝对时间比按照公认答案中建议的相对于当前计算时间要好。

与32位系统兼容的最大值为:

2147483647 = 2^31 = ~year 2038

你可以设置一个远离日期的日期,cookie是这样创建的:

var Cookie_expiry = new Date();
Cookie_expiry.setDate(Cookie_expiry.getDate()+10e5);   
// expiry date of cookie is set to be practically infinite (~ 4000 years)
setCookie('token', 'token_value', {expires: Cookie_expiry});

虽然这是不可能的,但你可以做一些类似谷歌所做的事情,将你的cookie设置为2038年1月17日或同样遥远的时间。

实际上,你最好将你的cookie设置为10年或60*60*24*365*10年,这应该比你的cookie所使用的大多数机器的寿命都长。