程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> 運行page頁面時的事件執行順序及頁面的回發與否深度了解

運行page頁面時的事件執行順序及頁面的回發與否深度了解

編輯:ASP.NET基礎
復制代碼 代碼如下:
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
public partial class _Default : Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
#region OnPreInit 第一步
protected override void OnPreInit(EventArgs e)
{
//檢查 IsPostBack 屬性來確定是不是第一次處理該頁。
//創建或重新創建動態控件。
//動態設置主控頁。
//動態設置 Theme 屬性。
//讀取或設置配置文件屬性值。
//注意
//如果請求是回發請求,則控件的值尚未從視圖狀態還原。如果在此階段設置控件屬性,則其值可能會在下一事件中被重寫。
base.OnPreInit(e);
}
#endregion
#region OnInit 第二步
protected override void OnInit(EventArgs e)
{
//在所有控件都已初始化且已應用所有外觀設置後引發。使用該事件來讀取或初始化控件屬性。
base.OnInit(e);
}
#endregion
#region OnInitComplete 第三步
protected override void OnInitComplete(EventArgs e)
{
//由 Page 對象引發。使用該事件來處理要求先完成所有初始化工作的任務。
base.OnInitComplete(e);
}
#endregion
#region PreLoad 第四步
protected override void OnPreLoad(EventArgs e)
{
//如果需要在 Load 事件之前對頁或控件執行處理,請使用該事件。
//在 Page 引發該事件後,它會為自身和所有控件加載視圖狀態,然後會處理 Request 實例包括的任何回發數據。
base.OnPreLoad(e);
}
#endregion
#region OnLoad 第五步
protected override void OnLoad(EventArgs e)
{
//Page 在 Page 上調用 OnLoad 事件方法,然後以遞歸方式對每個子控件執行相同操作,如此循環往復,直到加載完本頁和所有控件為止。
//使用 OnLoad 事件方法來設置控件中的屬性並建立數據庫連接。
base.OnLoad(e);
}
#endregion
#region 控件事件 第六步
protected void Button1_Click(object sender, EventArgs e)
{
//用這些事件來處理特定控件事件,如 Button 控件的 Click 事件或 TextBox 控件的 TextChanged 事件。
//注意
//在回發請求中,如果頁包含驗證程序控件,請在執行任何處理之前檢查 Page 和各個驗證控件的 IsValid 屬性。
}
#endregion
#region OnLoadComplete 第七步
protected override void OnLoadComplete(EventArgs e)
{
//對需要加載頁上的所有其他控件的任務使用該事件。
base.OnLoadComplete(e);
}
#endregion
#region OnPreRender 第八步
protected override void OnPreRender(EventArgs e)
{
//在該事件發生前:
//Page 對象會針對每個控件和頁調用 EnsureChildControls。
//設置了 DataSourceID 屬性的每個數據綁定控件會調用 DataBind 方法。有關更多信息,請參見下面的數據綁定控件的數據綁定事件。
//頁上的每個控件都會發生 PreRender 事件。使用該事件對頁或其控件的內容進行最後更改。
base.OnPreRender(e);
}
#endregion
#region SaveStateComplete 第九步
protected override void OnSaveStateComplete(EventArgs e)
{
//在該事件發生前,已針對頁和所有控件保存了 ViewState。將忽略此時對頁或控件進行的任何更改。
//使用該事件執行滿足以下條件的任務:要求已經保存了視圖狀態,但未對控件進行任何更改。
base.OnSaveStateComplete(e);
}
#endregion
#region Render 第十步
//Render
//這不是事件;在處理的這個階段,Page 對象會在每個控件上調用此方法。所有 ASP.NET Web 服務器控件都有一個用於寫出發送給浏覽器的控件標記的 Render 方法。
//如果創建自定義控件,通常要重寫此方法以輸出控件的標記。不過,如果自定義控件只合並標准的 ASP.NET Web 服務器控件,不合並自定義標記,則不需要重寫 Render 方法。有關更多信息,請參見開發自定義 ASP.NET 服務器控件。
//用戶控件(.ascx 文件)自動合並呈現,因此不需要在代碼中顯式呈現該控件。
#endregion
#region OnUnload 第十一步
protected override void OnUnload(EventArgs e)
{
//該事件首先針對每個控件發生,繼而針對該頁發生。在控件中,使用該事件對特定控件執行最後清理,如關閉控件特定數據庫連接。
//對於頁自身,使用該事件來執行最後清理工作,如:關閉打開的文件和數據庫連接,或完成日志記錄或其他請求特定任務。
//注意www.jb51.net
//在卸載階段,頁及其控件已被呈現,因此無法對響應流做進一步更改。如果嘗試調用方法(如 Response.Write 方法),則該頁將引發異常。
base.OnUnload(e);
}
#endregion
}

當頁面進行回發時,如點擊按鈕,以上事件都會重新執行一次,這時的執行順序為:
1. OnPreInit
2. OnInit
3. OnInitComplete
4. OnPreLoad
5. Page_Load
6. OnLoad
7. Button_Click
8. OnLoadComplete
9. OnPreRender
可以看到,Button_Click事件位於OnLoad之後執行,可以測試一下:
復制代碼 代碼如下:
public partial class TestControls : System.Web.UI.Page
{
static int count = 0;
protected void Page_Load(object sender, EventArgs e)
{
Response.Write(count+ "Page_Load <br />");
count++;
}
protected override void OnPreInit(EventArgs e)
{
base.OnPreInit(e);
Response.Write(count + "OnPreInit <br />");
count++;
}
protected override void OnInit(EventArgs e)
{
base.OnInit(e);
Response.Write(count + "OnInit <br />");
count++;
}
protected override void OnLoad(EventArgs e)
{
base.OnLoad(e);
Response.Write(count + "OnLoad <br />");
count++;
}
protected override void OnPreLoad(EventArgs e)
{
base.OnPreLoad(e);
Response.Write(count + "OnPreLoad <br />");
count++;
}
protected override void OnLoadComplete(EventArgs e)
{
base.OnLoadComplete(e);
Response.Write(count + "OnLoadComplete <br />");
count++;
}
protected override void OnInitComplete(EventArgs e)
{
base.OnInitComplete(e);
Response.Write(count + "OnInitComplete <br />");
count++;
}
protected override void OnUnload(EventArgs e)
{
base.OnUnload(e);
}
protected override void OnDataBinding(EventArgs e)
{
base.OnDataBinding(e);
Response.Write(count + "OnDataBinding <br />");
count++;
}
protected override void OnPreRender(EventArgs e)
{
base.OnPreRender(e);
Response.Write(count + "OnPreRender <br />");
count++;
}
protected void btnGraphics_Click(object sender, EventArgs e)
{
//Bitmap bmp = new Bitmap(10, 10);
//Graphics g = Graphics.FromImage(bmp);
Response.Write(count + "btnGraphics_Click <br />");
count++;
}
}

1.熟悉請求管道實現程序運行的全過程:
(1):BeginRequest: 開始處理請求
(2):AuthenticateRequest授權驗證請求,獲取用戶授權信息
(3):PostAuthenticateRequest獲取成功
(4): AunthorizeRequest 授權,一般來檢查用戶是否獲得權限
(5):PostAuthorizeRequest:獲得授權
(6):ResolveRequestCache:獲取頁面緩存結果
(7):PostResolveRequestCache 已獲取緩存
(8):PostMapRequestHandler 創建頁面對象
(9):AcquireRequestState 獲取Session-----先判斷當前頁面對象是否實現了IRequiresSessionState接口,如果實現了,則從浏覽器發來的請求報文體中獲得SessionID,並到服務器的Session池中獲得對應的Session對象,最後賦值給HttpContext的Session屬性
(10)PostAcquireRequestState 獲得Session
(11)PreRequestHandlerExecute:准備執行頁面對象
執行頁面對象的ProcessRequest方法
(12)PostRequestHandlerExecute 執行完頁面對象了
(13)ReleaseRequestState 釋放請求狀態
(14)PostReleaseRequestState 已釋放請求狀態
(15)UpdateRequestCache 更新緩存
(16)PostUpdateRequestCache 已更新緩存
(17)LogRequest 日志記錄
(18)PostLogRequest 已完成日志
(19)EndRequest 完成、
復制代碼 代碼如下:
public class getsession : System.Web.UI.Page, IReadOnlySessionState
{
string ss = "";
public void Init(HttpApplication context)
{
//這裡可以根據需求,添加各個請求管道
//獲取Session
context.AcquireRequestState += new EventHandler(context_AcquireRequestState);
//獲取Url
context.BeginRequest += new EventHandler(context_BeginRequest);
}
void context_AcquireRequestState(object sender, EventArgs e)
{
if (Session["user"] != null)
{
ss = Session["user"].ToString();
}
}
void context_BeginRequest(object sender, EventArgs e)
{
//獲得當前頁面請求管道的HttpApplication對象
HttpApplication application = sender as HttpApplication;
HttpContext context = application.Context;//獲得上下文對象
string url = context.Request.Url.LocalPath;//獲得URL(不包含域名和路徑)
}
}
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved