1. 程式人生 > >ASP.NET在IE10中無法判斷使用者已登入及Session丟失問題解決方法

ASP.NET在IE10中無法判斷使用者已登入及Session丟失問題解決方法

IE10中Session丟失問題引起眾多業內人士的關注,今天發現在IE10中登入網站時,使用表單驗證機制(FormsAuthentication)卻無法判斷該使用者已登入,儲存的Session總會丟失,本文將介紹解決方法,感興趣的朋友可以參考下,或許對你有所幫助

今天發現在IE10中登入我公司的一個網站時,點選其它選單,頁面總會自動重新退出到登入頁,後檢查發現,IE10送出的HTTP頭,和.AUTH Cookie都沒問題,但使用表單驗證機制(FormsAuthentication)卻無法判斷該使用者已登入,儲存的Session總會丟失.

後查實這是ASP.NET 2.0,3.5和4.0的Bugs,因這些版本無法識別IE10的User-Agent標頭字串,所以無法識別使用者瀏覽器的版本,從而導至了ASP.NET的特定功能失效,認為遊覽器不支援Cookies功能,不處理與Cookie相關的程式碼等,從而在瀏覽器中不儲存伺服器返回的Session標識,造成丟失等.

這個問題早經微軟官方確認,是IE10的一個Bug,也釋出了兩個HOTFIX專門用來修復這個問題,各位如遇到同樣的問題,可參考以下說明:
KB2600088: Hotfix 適用在 Microsoft.NET Framework 4.0 中的 ASP.NET  [英文]
KB2608565: Hotfix 適用在 .NET Framework 3.5.1 中的 ASP.NET  [英文]
KB2600100: Hotfix 適用在 .NET Framework 3.5 SP1 與 .NET Framework 2.0 SP2 中的 ASP.NET  [英文]
簡單的解決方法是,在網站根目錄,新增一個瀏覽器定義檔案(browser definition file)

步驟如下:
1.新增一個"App_Browsers"資料夾
2.新增一個"*.browser"字尾的檔案,如IE10.browser.
3.新增檔案內容如下:
複製程式碼 程式碼如下:
<browsers>
<browser refID="Default">
<capabilities><!-- To avoid wrong detections of e.g. IE10 -->
<capability name="cookies" value="true" />
<capability name="ecmascriptversion" value="3.0" />
</capabilities>
</browser>
</browsers>

設定完成,問題即可解決