[轉]錯誤與修復:ASP.NET無法檢測IE10,導致_doPostBack未定義JavaScript錯誤,恆處於FF5捲動條位置

[原文發表地址] Bug and Fix: ASP.NET fails to detect IE10 causing _doPostBack is undefined JavaScript error or maintain FF5 scrollbar position 

瀏覽器版本號繼續升級過程中。IE9誕生了,IE10 也即將問世火狐5和6已經發布了,而7和8也快出現了,Opera已經到了11,Chrome還在繼續,我也不知道,應該總在14和50之間吧。不管怎樣,不出意外版本號應該都會達到99。

__doPostBack error in IE10

在跟隨.NET 2.0和.NET 4一起發佈的瀏覽器定義文件中有一個錯誤,也就是它們保存相當一部分瀏覽器版本的定義。但是瀏覽器的有些版本(比如IE10)不再在這個範圍之內。因此,ASP.NET把它們看做是未知的瀏覽器,默認降級處理,這樣就會給用戶帶來不便,比如不支持JavaScript特性。

如果你想親自看看,那就創建一個全新的空白的網站(可以在Visual Studio 2010中試一下),添加一個需要JavaScript回調的控件(例如:<asp:LinkButton>),然後用IE9來運行站點(這是可行的)。再用IE10來運行(這就不行了)。查看一下頁面源代碼,比較一下發送到兩個版本的瀏覽器的HTML和JavaScript。

火狐5也遇到上述相似的問題,也就是無法檢測在瀏覽器中使用JavaScript重定位滾動條。這與爲Web Form 頁面而設的MaintainScrollbackPositionOnPostBack屬性不符。

這些“無法檢測”錯誤在ASP.NET 2和ASP.NET4中都影響了Web Form頁面。如果你使用的是ASP.NET Web頁面,或者是ASP.NET MVC,但沒有用瀏覽器對象去檢測JavaScript支持,那你就不再受影響的範圍內。

修復

有兩種修復這個錯誤的方法:一個就是整體修復,另一個就是單獨修復每個站點。

整體修復

我們正準備發佈一個Hotfix來修復這些問題,你可以通過KB文章來獲取。這些有修復 KB在一週內就會公佈了。它們可以再一部機器上永久解決所有頁面瀏覽器檢測問題。這些修復也會在以後版本的framework中運用,最終會成爲一個Windows更新。

· .NET 4 - http://support.microsoft.com/kb/2600088

·

· .NET 2.0 - http://support.microsoft.com/kb/2600100

修復所做的就是更新IE.瀏覽器和火狐瀏覽器的文件(路徑:\Windows\Microsoft.NET\Framework\<version>\Config\Browsers), 加上最新和未來已定義的版本號。不會影響其他任何東西。

單站點修復

clip_image004如果你無法訪問整部機器,或者只想更新單一的項目,那就通過NuGet安裝App_BrowsersUpdate包吧。然後你在方案瀏覽器(Solution Explorer)中的頁面結構就會如右圖所示。注意NuGet使用的是.NET 4,所以對於那些只有.NET 2的系統來說,你就還要獲取 ZIP文件,手動將新瀏覽器文件添加至App_Browsers目錄。

· .NET 4 瀏覽器更新 NuGet 包 - http://nuget.org/List/Packages/App_BrowsersUpdate

· 安裝包 App_BrowsersUpdate

· .NET 2.0 瀏覽器更新 NuGet 包 - http://nuget.org/List/Packages/App_BrowsersUpdate.net20

· 安裝包 App_BrowsersUpdate.net20

· 注意NuGet是VS2010特定版的,所以如果你沒有nuget.exe和.NET 4,你也可以手動地從這個zip文件中直接複製.NET 2的更新瀏覽器文件到~\App_Browsers.

要修復這個問題更新整部機器更可取。

總結

· ASP.NET 可能無法辨識出一些瀏覽器的最新版本,還會經常把它們看做是低級的瀏覽器。(也就是: 不支持JavaScript。)

· 修復是指更新瀏覽器定義文件。

· 你可以安裝整體修復或者單一修復某些項目。

· Hotfix會在幾周內問世。KB文章會屆時提供下載鏈接。

· 這些文件也會是之後.NET 4修復的一部分,預期也會在2012年1月通過Windows更新推送給用戶。

· 下一版本的.NET framework會包括所有的更新文件。

我上傳了已經更新的firefox.browser和ie.browser文件,,這些文件預計會在下一版本的ASP.NET中添加。文件和源代碼在我的BitBucket repo中。如果你想了解詳情,可以去看看。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章