這篇Blog來自一位同事和我的一次關於公司一個項目中的一個錯誤的討論。錯誤非常簡單,就是當在一個頁面的建構函式中使用類似:
Session[“aaa”] = “bbb”;
的時候,就會拋出異常,說系統中Session沒有被enable,所以不能使用(當然實際情況是肯定被enable了)。問題所在和解決方案也很快被找到了,在建構函式中不能使用Session的,將這個移到Page_Init中就OK了。
這個錯誤的根本原因應該是在頁面的建構函式被調用時,ASP.NET引擎中負責處理Session的SessionStateModule中相應初始化Session的代碼還沒有被執行,所以才導致了那時不能訪問當前內容相關的Session資訊。
SessionStateModule在其Init方法中,是在HttpApplication的AcquireRequestState事件(更確切說,應該是通過使用AddOnAcquireRequestStateAsync()方法,來進行非同步事件處理)上註冊了相應的方法,來完成初始化HttpSessionState對象,並將其賦值給當前的HttpContext的Session屬性,而在HttpApplication的AcquireRequestState事件被調用的時候,頁面對象已經被建立了,就是說,頁面的建構函式的執行是在AcquireRequestState事件被調用之前,所以在頁面建構函式中訪問Session當然會引發相應的異常。
HttpApplication的確切執行順序是:
BeginRequest -> AuthenticateRequest -> AuthorizeRequest -> ResolveRequestCache -> 構建頁面(在這裡頁面建構函式被調用) -> AcquireRequestState(這裡才初始化當前內容相關的Session) -> PreRequestHandlerExecute -> 進入頁面執行生命週期(開始Page_Init) -> PostRequestHandlerExecute -> ReleaseRequestState -> UpdateRequestCache -> EndRequest
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/DuSDong/archive/2004/10/29/157604.aspx