关于Session_End()运行机制的一些细节!
生活随笔
收集整理的這篇文章主要介紹了
关于Session_End()运行机制的一些细节!
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.首先是如何激發Session_End()方法
因為這個方法只支持InProc(進程內的)類型的Session,所以我們將Web.config配置如下:
<sessionState?timeout="1"?mode="InProc">
</sessionState> 注:timeout的基本單位是:分
2.為什么執行了Session.Abandon(),但是卻仍然可以從Session中取到值?
?? 為什么在Session_End()中,無法獲得HttpContext.Current對象?
按示例說明:
aspx部分
????<form?id="form1"?runat="server">
????????<div>
????????????<asp:Literal?ID="lblMsg"?runat="server"></asp:Literal>
????????????<br?/>
????????????<asp:Button?ID="btnTest"?runat="server"?Text="注銷Session"?OnClick="btnTest_Click"?/>????????????
????????????<asp:Button?ID="Button1"?runat="server"?Text="回發"?/>
????????</div>
????</form>
aspx.cs部分
????protected?void?Page_Load(object?sender,?EventArgs?e)
????{
????????if?(!Page.IsPostBack)
????????{
????????????this.Session["state"]?=?1;
????????}
????????this.lblMsg.Text?=?Convert.ToInt32(Session["state"]).ToString();
????}
????protected?void?btnTest_Click(object?sender,?EventArgs?e)
????{
????????this.Session.Abandon();
????????//?重新設置lblMsg.Text
????????this.lblMsg.Text?=?Convert.ToInt32(Session["state"]).ToString();
????}
Global.ascx部分
????void?Session_End(object?sender,?EventArgs?e)?
????{
????????try
????????{
????????????HttpContext.Current.Response.Write("調用Session_End()方法");
????????}
????????catch
????????{
????????????throw?new?Exception("捕獲異常");
????????}
????}
運行測試:
1)運行程序發現,點擊了“注銷Session”按鈕后,即使重新設置lblMsg.Text,輸出的值也仍然為1,并沒有像我們預期認為的那樣,應該是Session被注銷,然后通過Convert.ToInt32對NULL值的轉換后,輸出0。
2)現在給ASPX頁添加一個新的BUTTON控件,重新運行程序,依次點擊“注銷Session” - “回發”,發現在第2次點擊后,結果輸出0。通過調試也發現在調用Session.Abandon()后,的確進到了Session_End()方法。
注:通過調試發現,第一步和第二步均可以激發Session_End()方法。
調試分析:
1)前置條件:點擊“注銷Session”按鈕
給btnTest_Click()內的代碼設置斷點,通過調試可以發現,其中執行的順序并
不是:從Session.Abandon() - 到Session_End() - 執行完之后再返回到btnTest_Click()中繼續執行其他事件
而是:將btnTest_Click()中所有事件執行過后 - 再轉去執行Session_End()
2)前置條件:無
在Session_End()中設置斷點,然后正常啟動頁面,因為我將sessionState的timeout設置為1分鐘,所以干脆什么都不做,等1分鐘過去時,發現程序自動進到Session_End(),執行到這里思路應該就比較清楚了,正如cnblogs很多貼子中所說的“Session_End()是一個在服務器內部激發的事件處理函數,它是基于一個服務器內部的計時器的”,因為在激發該事件時服務器上并沒有相關的HttpRequest對象,所以也不存在HttpContext這個概念。至于為什么客戶端需要通過再一次Request回發請求,才會得到0,根據上面的第一步來看也就很明白了。
總結:
1)要激發Session_End(),必須正確配置Web.config,如<sessionState timeout="1" mode="InProc" />
2)Session_End()中是無法獲得HttpContext對象的。
3)執行Session.Abandon()后,客戶端必須至少有一次請求,才能正確反應Session的狀態。
因為這個方法只支持InProc(進程內的)類型的Session,所以我們將Web.config配置如下:
<sessionState?timeout="1"?mode="InProc">
</sessionState> 注:timeout的基本單位是:分
2.為什么執行了Session.Abandon(),但是卻仍然可以從Session中取到值?
?? 為什么在Session_End()中,無法獲得HttpContext.Current對象?
按示例說明:
aspx部分
????<form?id="form1"?runat="server">
????????<div>
????????????<asp:Literal?ID="lblMsg"?runat="server"></asp:Literal>
????????????<br?/>
????????????<asp:Button?ID="btnTest"?runat="server"?Text="注銷Session"?OnClick="btnTest_Click"?/>????????????
????????????<asp:Button?ID="Button1"?runat="server"?Text="回發"?/>
????????</div>
????</form>
aspx.cs部分
????protected?void?Page_Load(object?sender,?EventArgs?e)
????{
????????if?(!Page.IsPostBack)
????????{
????????????this.Session["state"]?=?1;
????????}
????????this.lblMsg.Text?=?Convert.ToInt32(Session["state"]).ToString();
????}
????protected?void?btnTest_Click(object?sender,?EventArgs?e)
????{
????????this.Session.Abandon();
????????//?重新設置lblMsg.Text
????????this.lblMsg.Text?=?Convert.ToInt32(Session["state"]).ToString();
????}
Global.ascx部分
????void?Session_End(object?sender,?EventArgs?e)?
????{
????????try
????????{
????????????HttpContext.Current.Response.Write("調用Session_End()方法");
????????}
????????catch
????????{
????????????throw?new?Exception("捕獲異常");
????????}
????}
運行測試:
1)運行程序發現,點擊了“注銷Session”按鈕后,即使重新設置lblMsg.Text,輸出的值也仍然為1,并沒有像我們預期認為的那樣,應該是Session被注銷,然后通過Convert.ToInt32對NULL值的轉換后,輸出0。
2)現在給ASPX頁添加一個新的BUTTON控件,重新運行程序,依次點擊“注銷Session” - “回發”,發現在第2次點擊后,結果輸出0。通過調試也發現在調用Session.Abandon()后,的確進到了Session_End()方法。
注:通過調試發現,第一步和第二步均可以激發Session_End()方法。
調試分析:
1)前置條件:點擊“注銷Session”按鈕
給btnTest_Click()內的代碼設置斷點,通過調試可以發現,其中執行的順序并
不是:從Session.Abandon() - 到Session_End() - 執行完之后再返回到btnTest_Click()中繼續執行其他事件
而是:將btnTest_Click()中所有事件執行過后 - 再轉去執行Session_End()
2)前置條件:無
在Session_End()中設置斷點,然后正常啟動頁面,因為我將sessionState的timeout設置為1分鐘,所以干脆什么都不做,等1分鐘過去時,發現程序自動進到Session_End(),執行到這里思路應該就比較清楚了,正如cnblogs很多貼子中所說的“Session_End()是一個在服務器內部激發的事件處理函數,它是基于一個服務器內部的計時器的”,因為在激發該事件時服務器上并沒有相關的HttpRequest對象,所以也不存在HttpContext這個概念。至于為什么客戶端需要通過再一次Request回發請求,才會得到0,根據上面的第一步來看也就很明白了。
總結:
1)要激發Session_End(),必須正確配置Web.config,如<sessionState timeout="1" mode="InProc" />
2)Session_End()中是無法獲得HttpContext對象的。
3)執行Session.Abandon()后,客戶端必須至少有一次請求,才能正確反應Session的狀態。
轉載于:https://www.cnblogs.com/cnxcfeng/archive/2008/05/09/1189171.html
總結
以上是生活随笔為你收集整理的关于Session_End()运行机制的一些细节!的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 读过的好书[技术类]
- 下一篇: 一个很好的视频网站