Your Privacy Matters: We use our own and third-party cookies to improve your experience on our website. By continuing to use the website we understand that you accept their use. Cookie Policy
340
UltraWebMenu 6.1 + ASP.NET 1.1 + IE 8
posted

With the release of IE 8 I have been experiancing issues with the UltraWebMenu 6.1 running under .NET 1.1

The first issue was that access was denied to HM_Arrays.js (I dont get this error in versions of IE prior to 8, nor did I get it in the IE 8 Beta releases).

The Second error is that the UltraWebMenu does not show up at all (shows up in IE < 7 and was showing in beta versions of IE8) in IE 8 release.

I could only get the second error to occur after I managed to clear the first error by grating ASPNET and IIS_WPG full control of the website.

 

Just a further tidbit. We had issues using Response.Browser.JavaScript. Apperntly this will always return false for IE 8 release (we had to comment out code that was using it). I belive this is related to Microsoft not supporting the .NET 1.1 framework and as such did not update the framework code that tells Response.Browser.JavaScript that IE 8 is a supported browser that has javascript. Which means that the UltraWebMenu could be using this same code, determining that IE 8 doesnt support javascript and hiding itself.

Parents
No Data
Reply
  • 5
    Suggested Answer
    posted

    Hi there,

     

    I have been struggling with this exact issue for quite a while, thinking that it's all server-side related, permissions related, etc., and here are my (very different) findings and solution:


    1. The problem is not related to IE 8.0, although it was happening to some of our clients who were, coincidentally exclusively, using IE 8.0. But, once we downgraded one of them to 6.0 and 7.0, the problems persisted.

     

    2. The issue happens at the core of the UltraWebMenu DLL deciding (on the server-side) which browser your user is using. If it decides that the browser is of "good" kind, then the result is positive and you get the page that you wanted, fully rendered. That would include references to 2 external script files: /ig_common/scripts/ig_csom.js and /ig_common/webbars2/ig_weblistbar.js. But, if the control decides that your browser is not what it wanted, then your user would get a much shorter HTML file, and only 1 tiny javascript file: /ig_common/webbars2/ig_weblistbarNS4.js.

    In other words, the control decided on the server-side that your user's browser is an ancient Netscape 4 browser, and thus it supports extremely limited functionality. In addition to this file, the "Netscape 4" users would also need to get the HM_Arrays.js, which, for whatever reason doesn't load well from the server. But, like I mentioned, it is merely a side-effect of the problem, and not the actual cause.

     

    3. The actual reason for this error in browser detection occurs due to a user-agent string that is too long. In my case, I was able to prove (with Fiddler) that when the user-agent string is longer than 240 characters (the value itself), Infragistics goes totally crazy and thinks that the user's browser is a Netscape 4, which then breaks everything else. Here is an example of my user's user-agent string, which took the UltraWebMenu out of control:

    User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; .NET CLR 1.1.4322; .NET CLR 2.0.50727; .NET CLR 3.0.04506.30; MDDR; .NET CLR 3.0.04506.648; .NET CLR 3.5.21022; OfficeLiveConnector.1.4; OfficeLivePatch.1.3; .NET CLR 3.0.4506.2152; .NET CLR 3.5.30729; .NET4.0C)

     

     

    The solution: see if this reasoning applies to you (you can look at your IIS logs, perform a TCP dump using Wireshark, or use Fiddler to capture HTTP traffic and then look at the user-agent string), and if yes, then: in your registry, Go to: HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Internet Settings\5.0\User Agent, and you will see a list your supported User-Agents. I'm sure you don't need all of them. Take one out (such as of these .NET CLRs), and try again. Here is a link explaining how to remove User-Agent values: http://www.pctools.com/guides/registry/detail/799

     

    Once you get back to the "safe" 240 characters limit, your web page will render perfectly well. I recommend to remove a couple of extra user-agent settings and buy yourself a little "cushion," just in case your user will add something in the future, and it will bounce back beyond the safety limit.

     

    Good luck!

    -- Isaac

Children
No Data