我正在开发一个需要状态良好的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
答案 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的值
...
所以你似乎缺少的是每个分号后的空格字符。