我读到一个在https连接下运行的页面不能与常规http下运行的另一个页面(或相同的内容)共享一个InProc会话(基于cookie).我的站点在Server 2003,IIS 6和.Net 2.0上运行.
在一些实验之后,看起来在通过https CAN连接时在会话中存储数据的页面随后访问数据,即使在普通的http下运行也是如此.
那么,是否有可能或者我应该过去寻找SSL配置中的缺陷?
来自MSDN:
当用户在安全区域和公共区域之间来回移动时,ASP.NET生成的会话cookie(如果您启用了无cookie会话状态,则为URL)以纯文本格式移动,但是身份验证cookie永远不会通过未加密的HTTP传递连接,只要设置了安全cookie属性.
所以基本上,如果Secure
属性设置为,则可以通过HTTP和HTTPS传递cookie false
.
我通过将此添加到我的Global.asax
文件中避免了此问题:
void Session_Start(object sender, EventArgs e) { if (Request.IsSecureConnection) Response.Cookies["ASP.NET_SessionID"].Secure = false; }
这意味着如果会话cookie是通过HTTP创建的,则只能通过HTTPS访问.
IIS设置在IIS属性窗口的ASP选项卡 - >会话属性下,有一个"安全连接上的新ID"设置
我通过将此设置为false来修复此间歇性问题.