Application_Start和Application_OnStart之间的区别

Cra*_*ker 38 asp.net asp.net-mvc global-asax

我正在将ASP.NET MVC代码添加到预先存在的ASP.NET Webforms项目中.的各种教程建议增加路由到从的Application_Start()在Global.asax中调用的方法.我的Global.asax已经有一个带有一些设置代码的Application_OnStart(Object,EventArgs)方法.

如果我尝试同时使用Start和OnStart,则不会调用OnStart(并且安装失败,导致错误).看起来我必须选择其中一个.

我的问题是:我应该使用哪一个?他们之间有什么区别?他们在不同的时间被召唤?

(注:在写这篇文章的时候,顶部 3 谷歌的点击率是无用的和/或误导性的,我希望堆栈溢出可以解决这个问题.)

Dyl*_*tie 75

在经典(遗留)ASP中,有一些特殊的函数名称,如果在global.asa文件中定义,将在应用程序生命周期中的指定点运行.这些定义为:

  • Application_OnStart - 在您的应用程序收到第一个HTTP请求时以及在处理任何.ASP文件之前运行一次.
  • Application_OnEnd - 在应用程序关闭期间,在处理完所有请求后运行一次.
  • Session_OnStart - 在每个唯一用户会话的开始处运行.如果用户/客户端禁用了cookie,则会针对每个请求运行,因为ASP从未检测到标识现有会话的会话cookie.
  • Session_OnEnd - (理论上!)每次用户会话到期时运行.祝你好运.

这些基本上是硬连接到经典ASP运行时 - 您无法更改它们,并且您不能将任何其他方法附加到这些事件.

在ASP.NET中,有一种称为AutoEventWireup使用反射来查找符合特定命名约定的方法,并运行这些方法以响应ASP.NET运行时引发的匹配事件.最常见的示例是该Page_Load方法,该方法会自动调用以响应Page类在页面生命周期中触发Load事件.

使用相同的技术将处理程序附加到应用程序级生命周期事件.它将查找名为ModuleName_EventName或ModuleName_OnEventName的方法,不带参数()(object sender, EventArgs e)

这是有趣的部分 - 如果您定义了多个匹配方法,则只会执行文件中最新显示的方法.(最后一种方法胜利,基本上)

所以如果你的global.asax.cs看起来像这样:

public class Global : System.Web.HttpApplication {
    protected void Application_Start() {
        Debug.WriteLine("A: Application_Start()");
    }

    protected void Application_Start(object sender, EventArgs e) {
        Debug.WriteLine("B: Application_Start(object sender, EventArgs e)");
    }

    protected void Application_OnStart() {
        Debug.WriteLine("C: Application_OnStart()");

    }
    protected void Application_OnStart(object sender, EventArgs e) {
        Debug.WriteLine("D: Application_OnStart(object sender, EventArgs e)");
    }
}
Run Code Online (Sandbox Code Playgroud)

你会在调试输出中看到消息D; 如果您注释掉该块中的最后一个方法,则会看到消息C.

因此 - 使用您喜欢的任何命名约定,但如果您定义多个命名约定,则只会执行源文件中最后出现的那个.我个人会坚持,Application_Start(object sender, EventArgs e)因为这是由Visual Studio项目模板和大多数.NET设计/编码工具生成的签名.


Par*_*ots 10

根据关于ASP.Net应用程序生命周期的Microsoft文档,您应该在global.asax文件中使用Application_start方法:

Application_Start:在请求ASP.NET应用程序中的第一个资源(例如页面)时调用.在应用程序的生命周期中,Application_Start方法仅被调用一次.您可以使用此方法执行启动任务,例如将数据加载到缓存中以及初始化静态值.

Application_OnStart:Application_OnStart事件发生在创建第一个新会话之前(首次引用Application对象时).这在Global.asa中,而不是global.asax.


Chr*_*isF 5

Application_OnStart:

在处理任何.asp文件之前调用Application_OnStart函数 - 在呈现任何文本或图形并将其发送到用户的浏览器之前.在此函数中,以下对Active Server Pages Server对象上的CreateObject方法的调用将创建CDO Rendering Library RenderingApplication对象.如果此调用成功,则objRenderApp变量包含指向新对象的指针.

我能找到的所有引用都引用.asp页面

Application_Start

Application_Start和Application_End方法是不代表HttpApplication事件的特殊方法.ASP.NET在应用程序域的生命周期内调用它们一次,而不是为每个HttpApplication实例调用它们.

此页面引用.aspx页面.因此,当您使用MVC并提及global.asax时,这是您应该使用的那个.