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

mru*_*lan 9 cookies rest session json http

我正在开发一个需要状态良好的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
Run Code Online (Sandbox Code Playgroud)

响应:

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
Run Code Online (Sandbox Code Playgroud)

gre*_*ner 2

根据标准规范,正确的语法是:

set-cookie-header = "Set-Cookie:" SP set-cookie-string
set-cookie-string = cookie-pair *( ";" SP cookie-av )
cookie-pair = cookie-name "= cookie-value
...

所以看来你缺少的是每个分号后面的空格字符。