web.cofig與Global.asax

可以瞭解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文件當中

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章