这是一个真正的挑战: 我已经在我的计算机上设置了IIS7.5并开始开发一个网站。每天晚上我都会在我的网络服务器上备份它,赢取2008r2 sp1(所有更新)。它完美无缺。
然而,在跨应用程序池共享cookie时遇到了一个巨大的问题。 www.example.com设置为127.0.0.1所以我可以在本地测试网站。它创建了Cookie但是当我删除HOSTS记录(指向Web服务器)时 - Web服务器上的应用程序池崩溃了。它每次都会发生,并且可能必须对sessionID cookie执行某些操作,因为没有cookie它会崩溃!
日志文件是:
Faulting application name: w3wp.exe, version: 7.5.7601.17514, time stamp: 0x4ce7afa2
Faulting module name: nlssorting.dll, version: 4.0.30319.239, time stamp: 0x4e182039
Exception code: 0xc00000fd
Fault offset: 0x0000000000001d7d
Faulting process id: 0x9f8
Faulting application start time: 0x01ccbbd76b7a443c
Faulting application path: c:\windows\system32\inetsrv\w3wp.exe
Faulting module path: C:\Windows\Microsoft.NET\Framework64\v4.0.30319\nlssorting.dll
Report Id: a9cfd0cf-27ca-11e1-bced-00215e5304da
发生了什么事?
答案 0 :(得分:0)
ASP.NET auth cookie使用web.config中的machineKey设置进行加密和解密。如果您没有,那么每次应用程序启动时都会自动生成。最好将其设置为固定值,以避免应用程序重新启动之间的cookie失效。
我无法确定,但可能是asp.net会话cookie也依赖于此加密密钥。我非常确定viewstate也在使用它(这就是为什么当应用程序因不活动而关闭后启动回发时会看到无效的viewstate错误。)
因此,尝试设置机器密钥并查看它仍然发生。您可以使用IIS生成一个,然后将其插入到web.config中的正确位置。