運行page頁面時的事件執行順序

来源:http://www.cnblogs.com/shouce/archive/2016/03/21/5300491.html
-Advertisement-
Play Games

當頁面進行回發時,如點擊按鈕,以上事件都會重新執行一次,這時的執行順序為: 1. OnPreInit2. OnInit3. OnInitComplete4. OnPreLoad5. Page_Load6. OnLoad7. Button_Click8. OnLoadComplete9. OnPreR


複製代碼
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.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(不包含功能變數名稱和路徑)
        }
    }
複製代碼

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 要使用Dictionary集合,需要導入C#泛型命名空間 System.Collections.Generic(程式集:mscorlib) 1、從一組鍵(Key)到一組值(Value)的映射,每一個添加項都是由一個值及其相關連的鍵組成 2、任何鍵都必須是唯一的 3、鍵不能為空引用null(VB中的N
  • 因為工作需要,需要做一個數據上傳的程式,客戶規定的是:數據介面採用http連接,採用JSON-RPC輕量級遠程調用協議。所以決定用winform做一個管理界面(其中還包括其他的功能),java完成數據的傳輸,用winform調用jar包來完成客戶需求。 具體做法如下(參考至http://blog.c
  • 今天是世界兒歌日,2016-3-21 ,下載個何問起鍵盤彈兒歌。何問起鍵盤 是一個 用電腦鍵盤彈奏音樂的軟體。 在上個版本 (http://www.cnblogs.com/sosoft/p/cspiano.html) 的基礎上,做了改進。 下載地址:http://hovertree.com/h/bj
  • 本來想遠程啟用下Guest賬戶測試一下(學習),但配置文件修改後總是不成功(沒有效果) 過程如下: 1:先找到配置文件地址 不錯,很貼心還有說明,在登錄賬戶的AppData下. 2:直接進入對應目錄: 恩恩,不錯,這裡還有example文件. 3:開始修改: 複製出一個rabbitmq.config
  • 背水一戰 Windows 10 之 UI: 視窗全屏, 視窗尺寸
  • 測試環境:Window Server 2008 CMD返回錯誤: 亂碼 解決方法: 該問題一般是由於系統環境變數沒有配置好引起的. 檢查以下兩個環境變數配置: 重新執行 安裝命令: rabbitmq-service.bat remove rabbitmq-service.bat install ra
  • 基礎篇:(學習能力取決於你的基礎扎不扎實) 第一步 掌握一門.NET面向對象語言,C#或VB.NET 我強烈反對在沒系統學過一門面向對象(OO)語言的前提下去學ASP.NET。 ASP.NET是一個全面向對象的技術,不懂OO,那絕對學不下去! 第二步 對.NET Framework類庫有一定的瞭解
  • JSON(全稱為JavaScript Object Notation) 是一種輕量級的數據交換格式。它是基於JavaScript語法標準的一個子集。 JSON採用完全獨立於語言的文本格式,可以很容易在各種網路、平臺和程式之間傳輸。JSON的語法很簡單,易於人閱讀和編寫,同時也易於機器解析和生成。 J
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...