我在Chrome浏览器中遇到了应用程序的奇怪行为(其他浏览器没问题)。当我刷新页面时,cookie正在正确发送,但是间歇性的浏览器似乎没有在一些刷新时传递cookie。
这就是我设置我的cookie的方式:
$identifier = / some weird string /;
$key = md5(uniqid(rand(), true));
$timeout = number_format(time(), 0, '.', '') + 43200;
setcookie('fboxauth', $identifier . ":" . $key, $timeout, "/", "fbox.mysite.com", 0);
这就是我用于页面标题的内容:
header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");
header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
header("Expires: Thu, 25 Nov 1982 08:24:00 GMT"); // Date in the past
您是否在此处看到任何可能影响Cookie处理的问题?谢谢你的任何建议。
似乎没有一些请求发送cookie。这种情况间歇性地发生,我现在看到所有浏览器的这种行为。有人遇到过这种情况吗?是否存在不随请求发送cookie的情况?
以下是HTTP标头:
Request Method:GET Status Code:200 OK
请求标题
Accept:application/xml,application/xhtml+xml,text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5 Referer:http://fbox.mysite.com/dashboard User-Agent:Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/532.5 (KHTML, like Gecko) Chrome/4.1.249.1045 Safari/532.5
响应标题
Cache-Control:no-cache, must-revalidate Content-Length:8903 Content-Type:text/html Date:Tue, 06 Apr 2010 09:25:26 GMT Expires:Thu, 25 Nov 1982 08:24:00 GMT Last-Modified:Tue, 06 Apr 2010 09:25:26 GMT Pragma:no-cache Server:Microsoft-IIS/7.5 X-Powered-By:PHP/5.3.1 ZendServer
再次感谢任何准则。
答案 0 :(得分:4)
一个问题,一个建议 -
问题 - 为什么你在time()上执行number_format(...),因为time()+ 43200就足够了。
建议 - 你看过客户端和服务器之间的时钟吗?由于你只给出了两者之间的12小时差异,如果在两台机器之间存在大的时钟偏差或者GMT时的分歧,你可能会发现你正在发送一个预定到期的cookie。不久的将来。
答案 1 :(得分:3)
在我看到你的标题信息后,我唯一能想到的是PHP在你设置cookie之前输出了一些东西。如果是这种情况,setcookie应返回false并且您将收到警告“无法发送会话Cookie - 已发送的标头”正如Bart S.建议的那样,打开error_reporting(E_ALL)
并尝试输出setcookie的返回值以进行验证事实并非如此。
另外,只需在基本情况下使用setcookie
只使用名称和值,然后再次检查响应标头。然后删除除setcookie之外的所有代码,如果有效,请使用除法和征服来恢复所有代码:)
答案 2 :(得分:1)
你处理你的cookie的方式完全没问题,代码中的一切似乎都没问题,问题似乎在于Chrome。
虽然Chrome Issue# 3014主要涉及Java applet,但似乎正是您所遇到的。
答案 3 :(得分:1)
我之前见过类似的问题。我会仔细检查路径是否正确。
我认为www.domain.com
与domain.com
不同,www.domain.com/
也是如此(尾随正斜杠)
除此之外,检查PHP是否有权将其会话写入具有正确写入权限的文件(根据发行版,它是一个不同的目录,但phpinfo()
应告诉您它尝试使用的目录。)
我之前遇到过这两个问题。第一个没有错误,似乎模仿你正在经历的,第二个给出了某种文件写入访问错误,但如果没有显示错误,你可能看不到。
答案 4 :(得分:1)
您的应用程序是通过http协议还是文件://?
提供的Chrome不会将Cookie存储在本地应用中,而且这是设计使然。您可以使用命令行开关更改此行为:
- 使文件饼干