转:运行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(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(不包含域名和路径) 
} 
} 

详细出处参考:http://www.jb51.net/article/33471.htm
相关文章
相关标签/搜索