For information on the general technique of embedding Windows Forms controls in web pages via <object> tags for viewing in Internet Explorer, take a look at these tutorials:
- Using Windows Forms Controls in Internet Explorer (WindowsForms.net) (Update 11/17/2008: Fixed this link, which had become broken on Microsoft's end.)
- Host Secure, Lightweight Client-Side Controls in Microsoft Internet Explorer (MSDN Magazine)
Tip: Viewing Fusion Bind errors from Internet Explorer
When a Windows Forms control fails to initially load properly, one or more "fusion bind errors" with information that may be helpful in diagnosing the problem may be logged.
Viewing fusion bind errors generated from errors loading .Net controls in Internet Explorer:
- Open the Temporary Internet Files folder in an Explorer window. (One way to do this is from Internet Explorer, select Tools | Options; on the Internet Options dialog, on the General tab, next to "Browsing History", click Settings; on the Temporary Internet Files and History Settings dialog, click "View files".)
- In the Temporary Internet Files explorer folder, sort by the Last Modified column to bring recent fusion bind error files to the top.
- Look for files named "?FusionBindError ...". You can't double-click these files to view them; instead, open a new Internet Explorer window, and drag one of the Fusion Bind Error files to the new window to view the contents.
Setting up .Net framework trust to allow Windows Forms controls hosted in a web page on a remote web server to run
For .Net controls embedded in web pages that perform certain types of operations, .Net framework code access security trust must be set up to allow the control to load and run; if this is not done, the security policy of the .Net framework on the client machine will prevent the control from loading.
If a .Net control does fail to load due to load due to .Net trust not being set up properly, the symptom will be an empty rectangle with a "colorful icon" present in the top-left corner displayed on the web page in place of the control. (See the FAQ section below.)
In an internal corporate / LAN environment, trust can be granted to the web server hosting the web page that includes the .Net control. This can be done from the client machine by using the Microsoft .Net Framework Configuration tool (if it is installed), or from the command line by using the caspol.exe utility.
Granting .Net trust to a specific web server with the Microsoft .Net Framework Configuration tool
This tool is not installed on all machines. (I'm not sure when/how the tool does get installed on machines where it is present.) On machines where the tool is present, it can be found in the Administrative Tools folder as "Microsoft .NET 2.0 Configuration", where "2.0" is the actual installed version of the .Net framework.
Be sure to set up trust using the version of the tool that matches the .Net version which Internet Explorer will be using to load and run .Net controls. (In most cases, this will be newest version of the .Net framework installed on the machine.)
Setting up .Net framework trust on a single client machine for controls running on a particular web server:
- Drill to .NET Framework Configuration | My Computer | Runtime Security Policy | Machine | Code Groups | All_Code.
- Right-click All_Code and choose New from the context menu.
- In the Create Code Group dialog that appears, enter a name for the new code group, then click Next. (The name can be anything, but I suggest using the name of the web server machine for which trust is to be established.)
- In step 2 ("Choose a condition type"), select URL from the dropdown; in the URL field that appears, enter "http://mywebserver/*", where mywebserver is the actual name of the web server to trust. (If you use SSL to connect to the web server, enter "https" instead of "http".)
- In step 3 ("Assign a Permission Set to the Code Group"), check the "Use existing permission set" radio button and select "FullTrust" from the dropdown. Click Next.
- Click Finish on the final step of the Wizard.
Granting .Net trust to a specific web server with the caspol.exe command-line utility
Caspol.exe is a command-line code access security policy tool that is installed with the .Net framework. Caspol.exe is located at:
%SystemRoot%\Microsoft.NET\Framework\v2.0.50727\caspol.exe
Where 2.0.50727 is the version number of the .Net framework installed on the client machine that IE is using to load the control. (2.0.50727 is the version number of the commercial release of the 2.0 .Net framework.)
Run the following command to establish .Net framework trust for a web server named serverName:
caspol -machine -addgroup 1 -url http://serverName/* FullTrust -name "http://serverName"
To view existing trust group settings set up on the local client machine, use:
caspol -lg
Regardless of which method is used to establish trust, after setting up trust for the web server, you'll need to close and re-open Internet Explorer to get it to pick up new trust setting.
The remainder of this document takes a FAQ format, with problems/issues in boldface and possible resolutions in plain type.
The "Colorful Icon" Issue
When attempting to load a Windows Forms control, the control does not appear; instead, a white box with a thin black outline appears in place of the control, with a colorful icon in the top-left corner.
A Windows Forms control that has failed to load, showing the "colorful icon"
Q: A Fusion Bind error is logged with this text: "System.Reflection.TargetInvocationException: Exception has been thrown by the target of an invocation. ---> System.Security.VerificationException: Operation could destabilize the runtime."
A: The most common cause of this problem is that the control requires .Net Framework trust to run, but trust has not been granted to the server hosting the control, or to the control itself, by the client machine (the computer where Internet Explorer is running). See "Setting up .Net framework trust" above.
Other general things to check for a control failing to load with the "colorful icon" symptom:
A: The client machine might be configured to not trust unsigned .Net or ActiveX controls in IE | Tools menu | Internet Options | Security tab. (Not sure about the exact setting.) Adding the web server to "Trusted Sites" on the client will generally fix this. (This seems particularly common when the client is Windows 2003 Server.)
A: If the class constructor of the .Net control is throwing an uncaught exception, this behavior will occur. Try stepping through the constructor in a debugger (assuming the control is one you are developing).
A: Try clearing the Temporary Internet Files on the client machine (especially if some .Net components in the browser are working, but not others).
A: If the same browser window was previously used to bring up the same .Net control from a different virtual directory on the server machine, close the browser window and use a new one.
A: There could be something invalid or malformed in the client machine's machine.config file.
A: There could be an invalid or malformed iexplore.exe.config file present in the same folder as the Internet Explorer executable (typically C:\Program Files\Internet Explorer\). Try temporarily renaming the iexplore.exe.config file to something else.
More specific symptoms and resolutions for situations where IE is showing the "colorful icon" in place of the .Net control after the control has failed to load:
Q: Client is connecting to server using SSL (https://...). Connecting to the server using a normal (non-SSL, http://...) connection does load controls correctly (if the server permits non-SSL connections).
A: Ensure that .Net framework trust is set up on the client machine for the web server machine with both the "https://" and "http://" prefixes (2 separate trust entries).
A: In Internet Explorer | Tools | Options | Advanced tab, uncheck "Do not save encrypted pages to disk".
Q: On the server machine, the most recent event in the IIS log is a 401 error trying to load a config file linked from the web page where the .Net control is located using a <LINK REL='Configuration' HREF='/configFile.conf'> tag. No Fusion Bind error is logged on the client.
A: Check the Windows filesystem permissions on the .conf file. Try giving the "Everyone" group full permissions on the file to establish whether or not this is the problem. (If applying "Everyone" permissions does work to resolve the issue, you will probably then wish to remove "Everyone," and apply more fine-grained permissions, to allow IIS to serve the control, but without compromising security.)
A: On the server, in IIS Manager, under File Security for the config file (for that specific file, not the parent virtual directory security), if Anonymous access is checked, ensure that "Allow IIS to control password" is also checked.
Q: Server OS is Windows 2003 Server. Navigating in the browser directly to the config file referenced in the .Net control's web page results in a 404 error (even though the file really is there on the server).
A: In the Internet Information Services Manager utility, open the Properties dialog for the config file's parent virtual directory. In the HTTP Headers tab, click the Mime Types... button, and add the config file's extension (.conf).
Q: A new .Net framework version was recently installed on the client, after which the control started failing to load.
A: Set up trust for the web server machine under the new .Net framework version (as described above).
Q: A Fusion Bind error shows a FileLoadException and error message text that talks about a DLL file version incompatibility. The control may load properly from a different client machine, or when a different user is logged into the OS.
A: Clear the Shadow Cache for the user on the machine where the problem is occurring. (The Shadow Cache is typically located at "C:\Documents and Settings\username\Local Settings\Application Data\assembly\dl?", where ? is a numeral. Delete the entire directory tree under the "dl?" folder to clear the cache. It may be necessary to enable viewing of hidden files/folders to see the cache.)
Q: When using compressed .cab files referenced from a .conf file on the server to deliver the .dll file(s) for the Windows Forms control, a fusion bind error shows "System.IO.FileNotFoundException: File or assembly name ControlType, or one of its dependencies, was not found.
A: This may indicate some problem on the server or client with loading .cab files. One possible cause: The MIME type associated with cabinet files (.cab) is incorrectly set in IIS (HTTP Headers | File Types) to a content type of "application/x-compressed"; the MIME type associated with a .cab file must be "application/octet-stream" for .Net to load the controls from the cab file. In inetmgr, in the HTTP headers tab, click File Types... and fix the setting.
Q: The Fusion Bind Error shows something like "System.TypeLoadException: Could not load type 'Typename' from assembly 'TypeName'"
A: The class name specified in the object tag needs to have correct casing (uppercase/lowercase). In the example above, you would need to change "Typename" to "TypeName".
"Vertical Scrollbar" issues
Q: When attempting to load a Windows Forms control, the control does not appear; instead, a white box with a thin black outline appears in place of the control, with a colorful icon in the top-left corner.
A: Check the classid parameter of the control's <object> tag to be sure it is pointing at a valid virtual directory.
A: Make sure that the DLL file referenced in the classid is present in the virtual directory.
A: Rarely, I've seen this issue happen when in on the server, IIS settings (inetmgr), Execute Permissions for the virtual directory is set to "Scripts and Executables". Try setting Execute Permissions to "Scripts only".
A: When debugging an ASP.NET page through Visual Studio 2005, apparently the "ASP.NET Development Server" that Visual Studio 2005 provides for debugging ASP.NET 2.0 apps doesn't support display of Windows Forms controls in the browser. Use the real IIS server on the machine instead. (You can debug the ASP.NET page running in IIS by manually attaching the Visual Studio debugger to the aspnet_wp.exe process once the ASP.NET site has been initially opened in the browser.)
"X" Icon Issues
Q: When attempting to load a .Net control, the control does not appear; instead, a white box with a thin black outline appears in place of the control, with an "X" icon in the top-left corner.
A Windows Forms control that has failed to load, showing the "X" icon
A: Make sure that the .Net framework has been installed on the client machine.
A: Check that a classid parameter is present in the <object> tag in the HTML source of the web page where the control is located.
A: Check the primary DLL file of the assembly that the control is attempting to load. (I've seen this happen in a contrived case when a control was trying to use a .dll file with file size 0.)
Other Issues
Q: When attempting to load a .Net control, an error dialog appears: "Your current security settings prohibit running ActiveX controls on this page. As a result, the page may not display correctly." After the dialog is dismissed, the control does not appear on the page at all.
A: In Internet Explorer, go to Tools | Internet Options | Security tab. Running signed ActiveX controls needs to be allowed for the "zone" that the web server is in; the zone settings can be changed to "Medium", or the web server can be added to a more trusted zone ("Local intranet" or "Trusted sites").
Q: After a .Net control loads, it appears correctly, but the user needs to click the control before it can be interacted with. Before the control is "activated", a tooltip appears when the mouse is hovered over the control with text "Press SPACEBAR or ENTER to activate and use this control" or text "Click to activate and use this control".
A: This issue is caused by a change that Microsoft was forced to introduce in Internet Explorer due to patent litigation between Microsoft and Eolas. For details and workarounds, see the article Activating ActiveX Controls on MSDN.
Q: When attempting to load a .Net control, the control does not appear; instead, a solid gray box with no error message text appears.
A: Check the syntax of the <object> tag in the HTML source. IE is probably not recognizing it as an attempt to show a Windows Forms control.
Scripting Issues
Q: When calling a public API method on a .Net control from Javascript running on the web page, the Javascript error "Object doesn't support this property or method" occurs.
A: The .Net control probably didn't load successfully. (This may be non-obvious if the control is hidden on the page.)
Q: A script call to a .Net control fails with the Javascript error message "Unexpected call to method or property access."
A: Apparently IE doesn't support child windows directly calling methods in Windows Forms controls located in a browser parent window (using syntax like "window.opener.document.ControlID.Method()") . As a workaround, rewrite the script to call a Javascript function on the parent page, then have the new function make the actual call to the .Net control.
Q: A script call to a .Net control fails with the Javascript error message "Invalid procedure call or argument."
A: The script code may be calling the method with an incorrect number of method parameters.
Debugging Issues
Q: After making a code change to the .Net Usercontrol and rebuilding, the changes made are not reflected in the browser window, even after refreshing the page.A: Close the current browser window, and reopen the web page in a new one.
Q: Can't hit breakpoints in the Visual Studio debugger when debugging a .NET Windows Forms object in the browser.
A: If launching the browser directly from Visual Studio, in Project Properties, on the Debug tab, make sure "Start external program" (pointing to iexplore.exe) is checked, not "Start browser with URL".
A: Make sure the DLL files used in the page being debugged are debug (not release) versions.
Q: When the Visual Studio 2003 .Net debugger is attached to an iexplore.exe instance, as soon as a .Net control starts loading, the browser closes and debugging ends. Both .Net 1.1 and 2.0 (or a later version) are installed on the machine. Q: Can't attach the VS.NET 2003 debugger to an iexplore.exe instance which is already running a .NET control.
A: Visual Studio 2003 can only debug .Net version 1.1 (not 2.0 or later versions), so you need to force IE to load controls using the 1.1 .Net framework. Create a new file named iexplore.exe.config in the Internet Explorer folder (the folder where iexplore.exe is located) with the following content:
<configuration> <startup> <requiredRuntime version="v1.1.4322"/> <supportedRuntime version="v1.1.4322"/> </startup> </configuration>
This will force Internet Explorer to load any .Net controls that it encounters in web pages in the 1.1 version of the .Net framework, beginning with the next time a fresh instance of Internet Explorer is opened.
When finished debugging in Visual Studio .Net 2003, remove the iexplore.exe.config file to permit .Net controls (and possibly also Internet Explorer extensions) which require .Net 2.0 to run properly once again.
The information in this post is current as of Internet Explorer 7 and the .Net framework 2.0.
Please note that this is not a comprehensive guide to all possible issues that may occur with running .Net Usercontrols in Internet Explorer; also, the troubleshooting suggestions here may not work to resolve a given issue in all cases. Please use caution when making configuration changes to your system (particularly security-related changes)!
Thanks so much for this. It is really helpful.
ReplyDeleteJon,
ReplyDeleteYour recommendations worked for some clients: WinXP SP2, Framework 2.0, Trusted Site, Framework SDK set trust to server. I have Win2003 Server and IIS 6.
I cannot see Windows Forms under Win2000 client, even with all the addons. Have you any ideas?
Helps a lot..!
ReplyDeleteI'm not able to drag my FusionBindError from the Temp Internet Files.Any suggestions?
oldseadog:
ReplyDeleteOn your Windows 2000 client, when the Windows Forms control(s) don't come up successfully, what do you see appear in the browser window where the control should normally appear? The "colorful icon" (as described in the post), or something else?
pradeep:
Can you be more specific about what happens when you try to drag a Fusion Bind Error item from your Temporary Internet Files folder to another folder?
This has helped me no end!
ReplyDeleteTHANKS
Great collection of troubleshooting tips. Keep up the good work
ReplyDeleteI have noticed that when I make a change to the Windows form control, I cannot see the changed version in the browser until I run gacutil /cdl. This occurs even when I increment the version number of the assembly.
ReplyDeleteRunning gacutil /cdl on every machine for actual deployments doesn't seem like a good solution.
Any ideas?
Hi Bina,
ReplyDeleteI don't think I've ever encountered that particular issue; it's been a little while now since I worked with development of Windows Forms controls hosted in IE, but if I recall correctly, I generally would see the control update in the browser as soon as I made a change to the control on the server. It wasn't necessary to update the control version number to see the change.
It sounds like what might be happening is that the client's cached version of the downloaded classes are not being cleared properly when a new version of the classes are present on the server.
The first thing I might look into is whether there is some configuration setting on the client that is affecting this behavior. Are you seeing this behavior on all client machines, or only on a particular one?
You might also take a look at the IIS request logs on your server to see whether or not the client is requesting the files for your updated classes; this might help give you some additional insight into what's going on.
Good luck with your troubleshooting!
Great post...your info fixed my issue. I was getting the 'disabled vertical scrollbar' symptom, which I resolved by setting IIS Execute Permissions on the subdirectory holding the control DLL to 'Scripts only'.
ReplyDeleteThanks again!
Thanks for posting this. It's been extremely helpful. By chance do you know of a what to show something other than the colorful icon when there is a load issue (i.e. some text or an image)?
ReplyDeletePaulG, you're welcome!
ReplyDeleteRegarding your question, do you mean that you'd like to show a more user-friendly error message on the screen when something goes wrong instead of just the broken control with the cryptic "colorful icon"? I'm not sure, off the top of my head -- I've not tried to do that, myself. Maybe you could write some Javascript that would try to access a property of the control, and if that fails, the script could write out the friendly error message at that point?
Hi Jon,
ReplyDeleteI really appreciate your Windows Forms in IE articles as I'm having trouble finding much information on the subject. I read through the article on allowing OpenFileDialog access to a windows form in IE but it seems to rely on the end user modifying their .Net security settings. How can I setup the application so that it performs the 'oneclick' trust style and allows the user to select files using the OpenFileDialog?
Thanks!
Hi Sam, thanks for the kind words! However, it's been a couple of years now since I've done any programming involving Windows Forms in IE, so I'm no longer in a very good position to answer questions about it. You might try asking over at the MSDN forums; but I agree, information about Windows Forms running in IE is hard to come by online. I always had trouble finding relevant information online when I was working in that technology (which was a primary impetus for putting this post together!).
ReplyDeleteThe answer to the following question is not of much help.
ReplyDeleteQ: When calling a public API method on a .Net control from Javascript running on the web page, the Javascript error "Object doesn't support this property or method" occurs.
A: The .Net control probably didn't load successfully. (This may be non-obvious if the control is hidden on the page.)
I am facing exactly the same problem and it would be of great help to me if you can suggest an appropriate solution. In my case, the control properties are being accessed without any problem in JavaScript but the problem is only with public methods/functions.
Thanks in advance.
Hi there!
ReplyDeleteCan i know how to change the virtual directory?
Im getting the A Windows Forms control that has failed to load, showing the "colorful icon" ~
i tried the possible methods stated above but still cant work.
Please help!!
Thanks.
I have embedded WindowscontrolLibrary on web page but I have two challenges:
ReplyDelete1) I cannot see the changed version in the browser when I make changes.
2) I followed steps on granting security but I still get sql security error.
Please help me out. Thanks
http://etlexperts.blogspot.com/2013/12/hosting-windows-forms-control-in.html
ReplyDeleteThe Windows forms control is working fine on clients machine with Windows 7 OS using IE 11 but it is not working on Windows 2012 server (i.e. It is citrix server where all the users login and access the website that has Windows forms controls). I have tried all the options mentioned in this site and also added EnableIEHosting value to 1 to registry. It is still not working.
ReplyDeletePlease help!
Thanks in advance.
The hotfix from KB article 2926995 did fix our issue on Windows 2012 server
ReplyDeleteThe Hotfix also worked for me on Windows 8.1 in conjunction with the EnableIEHosting Registry Key. Interestingly, I noticed that this can also be placed in HKCU, which might help some people as this of course does not require admin rights in order to set. You still need the patch however.
ReplyDeleteI wish comments were sorted chronologically (most recent first) as I spent 10 hours or more actively looking at this !
Hotfix Direct Link. If you are reading this and a long time has past since the hotfix release date, always check to see if there is a newer one https://support.microsoft.com/en-us/hotfix/kbhotfix?kbnum=2926995&kbln=en-us
ReplyDelete