可以瞭解web.cofig和Global.asax之間的關係以及執行的順序.
在Global.asax.cs文件中
protected void Application_BeginRequest(Object sender, EventArgs e)
{
Application["StartTime"] = System.DateTime.Now;
}
再在webform1中的page_load事件中添加
private void Page_Load(object sender, System.EventArgs e)
{
System.DateTime startTime = (System.DateTime)Application["StartTime"];
System.DateTime endTime = System.DateTime.Now;
System.TimeSpan ts = endTime - startTime;
Response.Write("頁面執行時間:"+ ts.Milliseconds +" 毫秒");
}
如果是05版本中,就要手動添加了,自己在App_Code中添加Global.asax.cs,然後設置Global.asax的屬性Inherits="Global"或CodeBehind="Global.asax.cs"即可<%@ Application Language="C#" Codebehind="Global.asax.cs" %>
以上測試在03/05均通過.
以下轉對Global.asax文件的瞭解
1 Global.asax文件的作用
先看看MSDN的解釋,Global.asax 文件(也稱爲 ASP.NET 應用程序文件)是一個可選的文件,該文件包含響應 ASP.NET 或HTTP模塊所引發的應用程序級別和會話級別事件的代碼。Global.asax 文件駐留在 ASP.NET 應用程序的根目錄中。運行時,分析 Global.asax 並將其編譯到一個動態生成的 .NET Framework 類,該類是從HttpApplication基類派生的。配置 ASP.NET,以便自動拒絕對 Global.asax 文件的任何直接的 URL 請求;外部用戶不能下載或查看其中的代碼。Global.asax 文件是可選的。只在希望處理應用程序事件或會話事件時,才應創建它.
2 Global.asax文件的創建
點擊Web站點>>添加新建項>>全局應用程序類,即可添加Global.asax文件。在.Net2003裏,直接右擊Global.asax文件查看代碼就可以編輯Global.asax.cs文件,但是在.Net2005中,沒有這個選項,因此需要自己在App_Code中添加Global.asax.cs,然後設置Global.asax的屬性Inherits="Global"或CodeBehind="Global.asax.cs"即可。不可知道還有沒有其他更好的方法。
3 Global.asax文件的執行
例如,IIS現在接到一個訪問ASP.NET應用程序的請求,這時候IIS會將這個請求映射給aspnet_isapi.dll,當aspnet_isapi.dll接到這個請求後,會新建一個aspnet_wp.exe的進程(windows server 2003下是w3wp.exe進程),這個進程會將請求傳遞給一個被指定的AppDomain,當這個AppDomain被創建時,就會去加載一些配置文件中的信息(加載順序是從machine.config文件到web.config文件中的一些相關配置),而當這些信息都被加載以後,AppDomain會去獲得一個HttpApplication的實例,這個時候global類就會被編譯加載了,接下來AppDomain會做一些相關的處理創建Page類的實例,最後這個頁面呈現到客戶端瀏覽器上。但這裏有一點問題需要注意,當配置文件被加載的時候,並不是表示AppDomain會加載配置文件中所有的信息,而僅是加載一些需要的信息。而有些配置信息是在需要時,纔會被AppDomain加載。例如我們在web.config文件中配置了很多HttpModule,但是僅當每一個HttpModule被訪問到時,AppDomain纔會去加載並處理這些信息。所以說web.config文件和global沒有先後執行的順序,只是視具體的信息什麼時候會被加載和處理。
4 Global.asax.cs中的方法的含義
Application_Init:在每一個HttpApplication實例初始化的時候執行
Application_Disposed:在每一個HttpApplication實例被銷燬之前執行
Application_Error:所有沒有處理的錯誤都會導致這個方法的執行
Application_Start:在程序初始化的時候執行。在Web應用程序的生命週期裏就執行一次,這裏只能放一些公用的信息,比如HttpApplicationState。
Application_End:應用程序結束時,在最後一個HttpApplication銷燬之後執行。對應Application_Start,在整個生命週期裏面也是隻執行一次。
Session_Start:會話開始時執行。
Session_End:會話結束或過期時執行。
Application_BeginRequest:BeginRequest是在收到Request時第一個觸發的事件,這個方法第一個執行。
Application_AuthenticateRequest:當安全模塊已經建立了當前用戶的標識後執行。
Application_AuthorizeRequest:當安全模塊已經驗證了當前用戶的授權時執行。
Application_ResolveRequestCache:當ASP.NET完成授權事件以使緩存模塊從緩存中爲請求提供服務時發生,從而跳過處理程序(頁面或者是WebService)的執行。這樣做可以改善網站的性能,這個事件還可以用來判斷正文是不是從Cache中得到的。
Application_AcquireRequestState:當ASP.NET獲取當前請求所關聯的當前狀態(如Session)時執行。
Application_PreRequestHandlerExecute:當ASP.Net即將把請求發送到處理程序對象(頁面或者是WebService)之前執行。這個時候,Session就可以用了。
Application_PostRequestHandlerExecute:當處理程序對象工作完成後執行。
Application_ReleaseRequestState:在ASP.NET執行完所有請求處理程序後執行。ReleaseRequestState事件將使當前狀態數據被保存。
Application_UpdateRequestCache:在ASP.NET執行完處理程序後爲了後續的請求而更新響應緩存時執行。
Application_EndRequest:同上,EndRequest是在響應Request時最後一個觸發的事件,這個方法自然就是最後一個執行的了。
Application_PreSendRequestHeaders:向客戶端發送Http標頭之前執行。
Application_PreSendRequestContent:向客戶端發送Http正文之前執行。
Request相應的事件執行順序:
1.BeginRequest 2.AuthenticateRequest 3.AuthorizeRequest 4.ResolveRequestCache 5.AcquireRequestState 6.PreRequestHandlerExecute 7.PostRequestHandlerExecute 8.ReleaseRequestState 9.UpdateRequestCache 10.EndRequest
方法使用範例:
void Application_Error(object sender, EventArgs e)
{
// 在出現未處理的錯誤時運行的代碼
Exception objErr = Server.GetLastError().GetBaseException();
StringBuilder error = new StringBuilder();
error.Append("異常時間:").Append(System.DateTime.Now.ToString()).Append(Environment.NewLine);
error.Append("異常頁面:").Append(Request.Url.ToString()).Append(Environment.NewLine);
error.Append("異常信息:").Append(objErr.Message).Append(Environment.NewLine);
error.Append("source:").Append(objErr.Source).Append(Environment.NewLine);
error.Append("錯誤方法:").Append(objErr.TargetSite.ToString()).Append(Environment.NewLine);
error.Append("用戶IP:").Append(Request.UserHostAddress).Append(Environment.NewLine);
error.Append("-------------------------------------------------------------------------------------------------").Append(Environment.NewLine);
Application["error"] = error;
lock (this)
{
using (StreamWriter sw = new StreamWriter(Server.MapPath("~/ErrorLog.txt"), true, Encoding.Default))
{
sw.WriteLine(error.ToString());
}
}
}
這樣,系統在發生沒有捕捉的錯誤的時候,就會把這個錯誤記錄到errorlog.txt文件當中