Select the product you need help with
- Internet Explorer
- Windows Phone
- More products
FIX: References to STA objects that are stored in session state may become corrupted if they are called from a Session_End event
Article ID: 827163 - View products that this article applies to.
For a Microsoft .NET Framework 1.1 version of this article, see 827164
If you store your references to single-threaded apartment (STA) objects in session state, and you set the AspCompat attribute to true, the references may become corrupted or may become lost when you try to gain access to the objects from the Session_End event.
Note Typically, this problem may occur if you run the application under high loads or if you use a stress tool such as Application Center Test (ACT) when you run the application. When this problem occurs, you receive a "0x8004e005 Error" error message in the event log.
The problem occurs because the Session_End event does not have to run on the same thread that the session was created on. Because the STA object is no longer on the same thread that the session was created on, you must use marshaling to gain access to the object. This behavior causes slow performance.
You can store STA objects in session state. However, Microsoft does not recommend that you do so. For more information, see the "References" section of this article.
This hotfix adds a new configuration setting to the Machine.config file. After you install the hotfix, the following application configuration is available.
By default, apartmentThreading is set to false. If you set apartmentThreading to true, the following behavior occurs:
This hotfix works for STA objects that are stored directly in session state. This hotfix also works for an STA object that is nested one level deep such as a .NET object that is stored in session state and that has a reference to an STA object. However, this hotfix does not work for STA objects that are stored more than one level deep.
A supported hotfix is now available from Microsoft, but it is only intended to correct the problem that is described in this article. Only apply it to systems that are experiencing this specific problem. This hotfix may receive additional testing. Therefore, if you are not severely affected by this problem, we recommend that you wait for the next Microsoft .NET Framework 1.0 service pack that contains this hotfix.
To resolve this problem immediately, contact Microsoft Product Support Services to obtain the hotfix. For a complete list of Microsoft Product Support Services telephone numbers and information about support costs, visit the following Microsoft Web site:
http://support.microsoft.com/contactus/?ws=supportNote In special cases, charges that are ordinarily incurred for support calls may be canceled if a Microsoft Support Professional determines that a specific update will resolve your problem. The usual support costs will apply to additional support questions and issues that do not qualify for the specific update in question.
The English version of this hotfix has the file attributes (or later file attributes) that are listed in the following table. The dates and times for these files are listed in Coordinated Universal Time (UTC). When you view the file information, it is converted to local time. To find the difference between UTC and local time, use the Time Zone tab in the Date and Time tool in Control Panel.
Date Time Version Size File name --------------------------------------------------------------------------------------------- 22-Sep-2003 19:32 1.0.3705.459 200,704 Aspnet_isapi.dll 22-Sep-2003 19:26 4,169 Aspnet_perf.h 22-Sep-2003 19:33 513,302 Aspnet_perf.ini 22-Sep-2003 19:33 510,714 Aspnet_perf2.ini 22-Sep-2003 19:32 1.0.3705.459 24,576 Aspnet_regiis.exe 22-Sep-2003 19:33 1.0.3705.459 28,672 Aspnet_wp.exe 22-Sep-2003 18:46 1.0.3705.459 69,632 Corperfmonext.dll 17-Jun-2003 22:43 16,597 Installpersistsqlstate.sql 17-Jun-2003 22:43 17,331 Installsqlstate.sql 09-Sep-2003 01:28 17,807 Installsqlstatetemplate.sql 22-Sep-2003 18:44 1.0.3705.459 303,104 Mscorjit.dll 23-Sep-2003 21:34 1.0.3705.459 1,953,792 Mscorlib.dll 22-Sep-2003 18:37 10,284 Mscorlib.ldo 22-Sep-2003 18:45 1.0.3705.459 2,273,280 Mscorsvr.dll 22-Sep-2003 18:45 1.0.3705.459 2,269,184 Mscorwks.dll 22-Sep-2003 19:30 1.0.3705.459 20,480 Perfcounter.dll 23-Aug-2002 03:23 15 Smartnav.htm 30-Jul-2003 01:04 8,728 Smartnav.js 23-Sep-2003 21:33 1.0.3705.459 1,175,552 System.dll 23-Sep-2003 21:32 1.0.3705.459 241,664 System.messaging.dll 23-Sep-2003 21:32 1.0.3705.459 311,296 System.runtime.remoting.dll 23-Sep-2003 21:31 1.0.3705.459 131,072 System.runtime.serialization.formatters.soap.dll 23-Sep-2003 21:34 1.0.3705.459 1,196,032 System.web.dll 23-Sep-2003 21:32 1.0.3705.459 507,904 System.web.services.dll 23-Sep-2003 21:34 1.0.3705.459 1,302,528 System.xml.dll 23-Sep-2003 21:30 1.0.3705.459 32,768 Tlbimp.exe 17-Jun-2003 22:43 1,419 Uninstallpersistsqlstate.sql 09-Sep-2003 01:28 2,119 Uninstallsqlstatetemplate.sql 23-Sep-2003 21:30 1.0.3705.459 65,536 Wsdl.exe
Microsoft has confirmed that this is a problem in the Microsoft products that are listed in the "Applies to" section.
This hotfix package also includes a secondary hotfix. If you set AspCompat to true, and you set an STA object that is stored in session state to null, you may receive a "NullReferenceException" error message when you reload the page. To reproduce the secondary problem, paste the following code inside a Page_Load event.
When you visit this page the first time, the code runs correctly. However, if you reload the page, you receive a "NullReferenceException" error message from Microsoft ASP.NET and you cannot view the page again in the current session.
If you set AspCompat to false, this behavior does not occur.
[NullReferenceException: Object reference not set to an instance of an object.] System.Web.UnsafeNativeMethods.AspCompatOnPageStart(Object obj) +0 System.Web.Util.AspCompatApplicationStep.OnPageStartSessionObjects() +90 System.Web.UI.Page.ProcessRequestMain() +44
Steps to Reproduce the BehaviorTo reproduce the problem that appears in the "Symptoms" section of this article, follow these steps:
For additional information, click the following article numbers to view the articles in the Microsoft Knowledge Base:
(http://support.microsoft.com/kb/243543/ )INFO: Do Not Store STA Objects in Session or Application
(http://support.microsoft.com/kb/243815/ )PRB: Storing STA COM Component in Session Locks Session Down to Single Thread
(http://support.microsoft.com/kb/817005/ )FIX: Severe Performance Issues When You Bind Session State to Threads in ASPCompat Mode
Article ID: 827163 - Last Review: October 25, 2005 - Revision: 1.6