System.Web.UI.Page 詳解(轉)
複製程式碼 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(objectsender, 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.2cto.com //在解除安裝階段,頁及其控制元件已被呈現,因此無法對響應流做進一步更改。如果嘗試呼叫方法(如 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(不包含域名和路徑) } }
原文地址:https://www.cnblogs.com/knowledgesea/archive/2013/01/21/2865842.html