IE Error: '__doPostBack' is undefined 问题解决
突然遇到个很奇怪的BUG,翻页控件,其他浏览器一切正常,IE无法翻页,会提示 '__doPostBack' is undefined
后来搜索发现:
[原文發表地址] Bug and Fix: ASP.NET fails to detect IE10 causing _doPostBack is undefined JavaScript error or maintain FF5 scrollbar position
[原文發表時間] 2009-05-20 01:41
瀏覽器版本號繼續升級過程中。IE9誕生了,IE10 也即將問世,火狐5和6已經發布了,而7和8也快出現了,Opera已經到了11,Chrome還在繼續,我也不知道,應該總在14和50之間吧。不管怎样,不出意外版本號應該都會達到99。
在跟隨.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://go.rritw.com/support.microsoft.com/kb/2600088
·
· .NET 2.0 - http://go.rritw.com/support.microsoft.com/kb/2600100
修复所做的就是更新IE.瀏覽器和火狐瀏覽器的文件(路徑:\Windows\Microsoft.NET\Framework\<version>\Config\Browsers), 加上最新和未來已定義的版本號。不會影響其他任何東西。
單站點修复
如果你無法訪問整部機器,或者只想更新單一的項目,那就通過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中。如果你想了解詳情,可以去看看。