我这里有(浏览器)cookie问题。
我有一个Sharepoint页面(http:// myServer:24628 / sites / myApp / myDocumentLibrary / test.aspx)。当请求页面时,我可以在请求标题中看到(使用firebug)有一个ASP.NET_SessionId cookie。
请求标头:
Host: myServer:24628
User-Agent: Mozilla/5.0 (Windows NT 6.1; rv:7.0.1) Gecko/20100101 Firefox/7.0.1
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-us,en;q=0.5
Accept-Encoding: gzip, deflate
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7
Connection: keep-alive
Cookie: ASP.NET_SessionId=2vhaxii0hxqeazii2sgw3q55; WSS_KeepSessionAuthenticated=24628
If-Modified-Since: Thu, 27 Oct 2011 15:41:15 GMT
Cache-Control: max-age=0
响应标头:
Cache-Control: private, max-age=0
Content-Length: 210604
Content-Type: text/html; charset=utf-8
Expires: Wed, 12 Oct 2011 15:41:24 GMT
Last-Modified: Thu, 27 Oct 2011 15:41:24 GMT
Server: Microsoft-IIS/6.0
X-Powered-By: ASP.NET
MicrosoftSharePointTeamServices: 12.0.0.6421
X-AspNet-Version: 2.0.50727
Set-Cookie: WSS_KeepSessionAuthenticated=24628; path=/
http%3A%2F%2FmyServer%3A24628%2Fsites%2FmyApp%2FDiscovery=WorkspaceSiteName=UG9ydGFs&WorkspaceSiteUrl=aHR0cDovL3dlYmFwcDAxOjI0NjI4L3NpdGVzL251bnRpbw==&WorkspaceSiteTime=MjAxMS0xMC0yN1QxNTo0MTozMQ==; expires=Sat, 26-Nov-2011 16:41:31 GMT; path=/_vti_bin/Discovery.asmx
Date: Thu, 27 Oct 2011 15:41:31 GMT
页面加载后,我发出asmx请求(POST):
请求标头:
Host myServer:24628
User-Agent Mozilla/5.0 (Windows NT 6.1; rv:7.0.1) Gecko/20100101 Firefox/7.0.1
Accept text/javascript, text/html, application/xml, text/xml, */*
Accept-Language en-us,en;q=0.5
Accept-Encoding gzip, deflate
Accept-Charset ISO-8859-1,utf-8;q=0.7,*;q=0.7
Connection keep-alive
X-Requested-With XMLHttpRequest
X-Prototype-Version 1.7
Content-Type application/json; charset=UTF-8
Referer http://myServer:24628/sites/myApp/myDocumentLibrary/test.aspx
Content-Length 42
Cookie WSS_KeepSessionAuthenticated=24628
在进行asmx调用之前,我会提醒'ASP.NET_SessionId'cookie的值。它在那里,它的价值是正确的。
在notify.asmx调用中,我需要检索cookie值才能运行某些逻辑。这显然是失败的 这里发生了什么?
噢,是的,
马努。
答案 0 :(得分:2)
您的Cookie未发送,因为两个请求的主机字段不同:
主持人:webapp01:24628
主机myServer:24628
答案 1 :(得分:1)
javascript确实是从其他位置加载的。正如克里斯·莱弗利在评论中提出的那样。
答案 2 :(得分:0)
覆盖所有基地,你有[WebMethod(EnableSession = true)]
吗?
这只发生在IE吗?仅在IE上看过这个,不得不添加一个P3P标头条目,但这是针对跨域SSO解决方案。