Set-Cookie Header位于响应中,但浏览器未在下一个请求中设置Cookie

时间:2012-04-20 19:06:05

标签: json http session rest cookies

我正在开发一个需要状态良好的REST Api(没有解决方法,我使用的是没有可序列化对象的本机库等。)

此Rest API在域domainA上的Web服务器上公开。 响应包含一个设置为*的Access-Control-Allow-Origin标头,所以我不需要JSON-P。 (我不知道这个细节是否关心。)

我在请求DomainA的domainB上做了一个GWT使用此API的示例。浏览器不会添加先前设置的cookie。它的作品“无国籍”。

样本是否也必须在DomainA上? 是否有设置工作区或特定标题?

修改: 我在Cookie中设置了一个主域名。它不起作用。浏览器仍然没有在下一个请求标头中设置cookie会话。

请求:

HeadersPreviewResponseCookiesTiming
Request URL:http://subdomainB.mydomain.com/request
Request Method:POST
Status Code:200 OK
Request Headersview source
Accept:*/*
Accept-Charset:ISO-8859-1,utf-8;q=0.7,*;q=0.3
Accept-Encoding:gzip,deflate,sdch
Accept-Language:fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4
Connection:keep-alive
Content-Length:1185
Content-type:application/x-www-form-urlencoded
Host:subdomainB.mydomain.com
Origin:http://subdomainA.mydomain.com
Referer:http://subdomainA.mydomain.com/BLABLABLA
User-Agent:Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/536.8 (KHTML, like Gecko) Chrome/20.0.1105.0 Safari/536.8

响应:

Response Headersview source
Access-Control-Allow-Origin:*
Cache-Control:no-cache, no-store, max-age=0
Connection:Keep-Alive
Content-Language:fr-FR
Content-Type:application/json;charset=UTF-8
Date:Wed, 25 Apr 2012 07:59:03 GMT
Expires:Thu, 01 Jan 1970 00:00:00 GMT, Thu, 01 Jan 1970 00:00:00 GMT
Keep-Alive:timeout=15, max=100
Pragma:no-cache
Server:Jetty(7.5.4.v20111024)
Set-Cookie:JSESSIONID=cookieValue;Path=/;Domain=.mydomain.com
Transfer-Encoding:chunked

1 个答案:

答案 0 :(得分:2)

根据standards spec,正确的语法是:

  

set-cookie-header =" Set-Cookie:" SP set-cookie-string
  set-cookie-string = cookie-pair *(&#34 ;;" SP cookie-av)
  cookie-pair = cookie-name" =" cookie的值
  ...

所以你似乎缺少的是每个分号后的空格字符。