The Global.asax file, sometimes called the ASP.NET application file, provides a way to respond to application or module level events in one central location. You can use this file to implement application security, as well as other tasks. Let's take a closer look at how you may use it in your application development efforts.

Overview

The Global.asax file is in the root application directory. While
Visual Studio .NET automatically inserts it in all new ASP.NET projects,
it's actually an optional file. It's okay to delete it--if you aren't
using it. The .asax file extension signals that it's an application file
rather than an ASP.NET file that uses aspx.

The Global.asax file is configured so that any direct HTTP request
(via URL) is rejected automatically, so users cannot download or view
its contents. The ASP.NET page framework recognizes automatically any
changes that are made to the Global.asax file. The framework reboots the
application, which includes closing all browser sessions, flushes all
state information, and restarts the application domain.

Programming

The Global.asax file, which is derived from the HttpApplication
class, maintains a pool of HttpApplication objects, and assigns them to
applications as needed. The Global.asax file contains the following
events:

  • Application_Init: Fired when an application initializes or is
    first called. It's invoked for all HttpApplication object instances.
  • Application_Disposed: Fired just before an application is
    destroyed. This is the ideal location for cleaning up previously used
    resources.
  • Application_Error: Fired when an unhandled exception is encountered within the application.
  • Application_Start: Fired when the first instance of the
    HttpApplication class is created. It allows you to create objects that
    are accessible by all HttpApplication instances.
  • Application_End: Fired when the last instance of an
    HttpApplication class is destroyed. It's fired only once during an
    application's lifetime.
  • Application_BeginRequest: Fired when an application request is
    received. It's the first event fired for a request, which is often a
    page request (URL) that a user enters.
  • Application_EndRequest: The last event fired for an application request.
  • Application_PreRequestHandlerExecute: Fired before the ASP.NET
    page framework begins executing an event handler like a page or Web
    service.
  • Application_PostRequestHandlerExecute: Fired when the ASP.NET page framework is finished executing an event handler.
  • Applcation_PreSendRequestHeaders: Fired before the ASP.NET page framework sends HTTP headers to a requesting client (browser).
  • Application_PreSendContent: Fired before the ASP.NET page framework sends content to a requesting client (browser).
  • Application_AcquireRequestState: Fired when the ASP.NET page
    framework gets the current state (Session state) related to the current
    request.
  • Application_ReleaseRequestState: Fired when the ASP.NET page
    framework completes execution of all event handlers. This results in all
    state modules to save their current state data.
  • Application_ResolveRequestCache: Fired when the ASP.NET page
    framework completes an authorization request. It allows caching modules
    to serve the request from the cache, thus bypassing handler execution.
  • Application_UpdateRequestCache: Fired when the ASP.NET page
    framework completes handler execution to allow caching modules to store
    responses to be used to handle subsequent requests.
  • Application_AuthenticateRequest: Fired when the security module
    has established the current user's identity as valid. At this point, the
    user's credentials have been validated.
  • Application_AuthorizeRequest: Fired when the security module has verified that a user can access resources.
  • Session_Start: Fired when a new user visits the application Web site.
  • Session_End: Fired when a user's session times out, ends, or they leave the application Web site.

The event list may seem daunting, but it can be useful in various circumstances.

Triggering

A key issue with taking advantage of the events is knowing the order
in which they're triggered. The Application_Init and Application_Start
events are fired once when the application is first started. Likewise,
the Application_Disposed and Application_End are only fired once when
the application terminates. In addition, the session-based events
(Session_Start and Session_End) are only used when users enter and leave
the site. The remaining events deal with application requests, and
they're triggered in the following order:

  • Application_BeginRequest
  • Application_AuthenticateRequest
  • Application_AuthorizeRequest
  • Application_ResolveRequestCache
  • Application_AcquireRequestState
  • Application_PreRequestHandlerExecute
  • Application_PreSendRequestHeaders
  • Application_PreSendRequestContent
  • <<code is executed>>
  • Application_PostRequestHandlerExecute
  • Application_ReleaseRequestState
  • Application_UpdateRequestCache
  • Application_EndRequest

Applying to security

A common use of some of these events is security. The following C#
example demonstrates various Global.asax events with the
Application_Authenticate event used to facilitate forms-based
authentication via a cookie. In addition, the Application_Start event
populates an application variable, while Session_Start populates a
session variable. The Application_Error event displays a simple message
stating an error has occurred.

protected void Application_Start(Object sender, EventArgs e) {

Application["Title"] = "Builder.com Sample";

}

protected void Session_Start(Object sender, EventArgs e) {

Session["startValue"] = 0;

}

protected void Application_AuthenticateRequest(Object sender, EventArgs e) {

// Extract the forms authentication cookie

string cookieName = FormsAuthentication.FormsCookieName;

HttpCookie authCookie = Context.Request.Cookies[cookieName];

if(null == authCookie) {

// There is no authentication cookie.

return;

}

FormsAuthenticationTicket authTicket = null;

try {

authTicket = FormsAuthentication.Decrypt(authCookie.Value);

} catch(Exception ex) {

// Log exception details (omitted for simplicity)

return;

}

if (null == authTicket) {

// Cookie failed to decrypt.

return;

}

// When the ticket was created, the UserData property was assigned

// a pipe delimited string of role names.

string[2] roles

roles[0] = "One"

roles[1] = "Two"

// Create an Identity object

FormsIdentity id = new FormsIdentity( authTicket );

// This principal will flow throughout the request.

GenericPrincipal principal = new GenericPrincipal(id, roles);

// Attach the new principal object to the current HttpContext object

Context.User = principal;

}

protected void Application_Error(Object sender, EventArgs e) {

Response.Write("Error encountered.");

}

This example provides a peek at the usefulness of the
events contained in the Global.asax file; it's important to realize
that these events are related to the entire application. Consequently,
any methods placed in it are available through the application's code,
hence the Global name.

Here's the VB.NET equivalent of the previous code:

Sub Application_Start(ByVal sender As Object, ByVal e As EventArgs)

Application("Title") = "Builder.com Sample"

End Sub

Sub Session_Start(ByVal sender As Object, ByVal e As EventArgs)

Session("startValue") = 0

End Sub

Sub Application_AuthenticateRequest(ByVal sender As Object, ByVal e As

 EventArgs)

' Extract the forms authentication cookie

Dim cookieName As String

cookieName = FormsAuthentication.FormsCookieName

Dim authCookie As HttpCookie

authCookie = Context.Request.Cookies(cookieName)

If (authCookie Is Nothing) Then

' There is no authentication cookie.

Return

End If

Dim authTicket As FormsAuthenticationTicket

authTicket = Nothing

Try

authTicket = FormsAuthentication.Decrypt(authCookie.Value)

Catch ex As Exception

' Log exception details (omitted for simplicity)

Return

End Try

Dim roles(2) As String

roles(0) = "One"

roles(1) = "Two"

Dim id As FormsIdentity

id = New FormsIdentity(authTicket)

Dim principal As GenericPrincipal

principal = New GenericPrincipal(id, roles)

' Attach the new principal object to the current HttpContext object

Context.User = principal

End Sub

Sub Application_Error(ByVal sender As Object, ByVal e As EventArgs)

Response.Write("Error encountered.")

End Sub

A good resource

The Global.asax file is the central point for ASP.NET applications.
It provides numerous events to handle various application-wide tasks
such as user authentication, application start up, and dealing with user
sessions. You should be familiar with this optional file to build
robust ASP.NET-based applications.

我能在Global.asax文件中触发那些事件?
Application对象创建和结束时所触发的事件有

 Application_Start

 Application_End

Session对象创建和结束时所触发的事件有

• Session_Start

• Session_End

对程序有请求发生时触发的事件有 (按发生顺序排列)

• Application_BeginRequest

• Application_AuthenticateRequest

• Application_AuthorizeRequest

• Application_ResolveRequestCache

• Application_AcquireRequestState

• Application_PreRequestHandlerExecute

• Application_PostRequestHandlerExecute

• Application_ReleaseRequestState

• Application_UpdateRequestCache

• Application_EndRequest

当有程序有错误发生时触发的事件有

• Application_Error

• Application_Disposed

Global中的事件执行顺序的更多相关文章

  1. jquery中各个事件执行顺序如下:

    jquery中各个事件执行顺序如下: 1.ajaxStart(全局事件) 2.beforeSend 3.ajaxSend(全局事件) 4.success 5.ajaxSuccess(全局事件) 6.e ...

  2. jquery ajax 中各个事件执行顺序

    jquery ajax 中各个事件执行顺序如下: 1.ajaxStart(全局事件) 2.beforeSend 3.ajaxSend(全局事件) 4.success 5.ajaxSuccess(全局事 ...

  3. jquery ajax中各个事件执行顺序如下

    $(function(){ setTimeout(function(){ $.ajax({ url:'/php/selectStudent.php', }); },0); $(document).aj ...

  4. jquery ajax 事件执行顺序

    jquery中各个事件执行顺序如下: 1.ajaxStart(全局事件) 2.beforeSend 3.ajaxSend(全局事件) 4.success 5.ajaxSuccess(全局事件) 6.e ...

  5. jquery ajax事件执行顺序

    jquery中各个事件执行顺序如下: 1.ajaxStart(全局事件) 2.beforeSend 3.ajaxSend(全局事件) 4.success 5.ajaxSuccess(全局事件) 6.e ...

  6. Unity3D中脚本的执行顺序和编译顺序

    http://www.cnblogs.com/champ/p/execorder.html 在Unity中可以同时创建很多脚本,并且可以分别绑定到不同的游戏对象上,它们各自都在自己的生命周期中运行.与 ...

  7. ASP.NET Page对象各事件执行顺序(转)

    很久没写 asp.net 的东西了,search 了一下 page 的事件执行顺序,找到如下的东西,仅仅做记录用 Page.PreInit 在页初始化开始时发生 Page.Init 当服务器控件初始化 ...

  8. 【转】Unity3D中脚本的执行顺序和编译顺序(vs工程引用关系)

    http://www.cnblogs.com/champ/p/execorder.html 在Unity中可以同时创建很多脚本,并且可以分别绑定到不同的游戏对象上,它们各自都在自己的生命周期中运行.与 ...

  9. Web高级 Eventloop和事件执行顺序

    1. EventLoop 1.1 调用栈 当一个方法执行时内部调用另外的方法,则会形成调用栈,如图: 1.2 任务队列 JavaScript有一个主线程执行当前任务,主线程的代码同步执行,并把遇到的事 ...

随机推荐

  1. dede-搜索

    <form name="formsearch" action="{dede:global.cfg_cmsurl/}/plus/search.php"> ...

  2. ACM——快速排序法

    快速排序 时间限制(普通/Java):1000MS/3000MS          运行内存限制:65536KByte总提交:653            测试通过:297 描述 给定输入排序元素数目 ...

  3. onActivityResult调用不到的问题

    有可能是调用时机不对,请转移到: http://www.cnblogs.com/shaweng/p/3875825.html 还有可能是Activity的launchmode导致的 使用 androi ...

  4. 20个linux命令行工具监视性能(上)

    对于每一个系统管理员或网络管理员每天监视或调试linux系统的性能问题是一件非常困难的事,在it行业作为一个linux管理员五年之后,我开始知道监视和保持系统启动和运行有多么的困难.由于这个原因,我们 ...

  5. java多线程总结二:后台线程(守护线程)

    所谓的后台线程,是指在程序运行的时候在后台提供一种通用服务的线程,并且这种线程并不属于程序中不可或缺的部分.因此当所有的非后台线程结束时,程序也就终止了,同时会杀死所有后台线程.反过来说,只要有任何非 ...

  6. croppic 图片裁剪

    #region 3.1.3 保存裁剪后的图片方法 +ContentResult TemplateCropImg() /// <summary> /// 保存裁剪后的图片方法 /// < ...

  7. Jquery中Ajax异步请求中的async参数的作用

    之前不知道这个参数的作用,上网找了前辈的博客,在此收录到自己的博客,希望能帮到更多的朋友: test.html <a href="javascript:void(0)" on ...

  8. ios 兼容IPV4和IPV6网络通信

    前言: 苹果官方出了新的规定,要求新上架的app都必须单独支持ipv6-only的网络. 准备工作: 搭建IPV6测试环境:http://blog.csdn.net/potato512/article ...

  9. 添加数据库的Maven依赖(SqlServer,Oracle)

    oracle: 1.在Oracle官网下载ojdbc的jar包 例:ojdbc7.jar,版本是12.1.0.2,存储地址/home/peng/下载 2.dos中进入存储地址执行如下命令行(注意各项对 ...

  10. Oracle每10天删除数据,并重建索引

    declare datDateFrom date := to_date('2010/08/01 00:00:00','yyyy/mm/dd hh24:mi:ss'); datDateTo date; ...