为了在用户访问网站时始终向用户显示“友好”错误页面,我在Global.asax页面中找到了一个全能的错误,大多数错误都由过滤器处理,这似乎是首选方法。在大多数情况下,这很好。但是,在Application_Start期间,Application_Error事件(可以理解)不会被触发。
我的Application_Start事件包含一些依赖于服务调用的初始化代码,因此如果服务因任何原因不可用,则容易定义的失败点。我发现解决这个问题的唯一方法是执行以下操作。
private static Exception StartUpException;
protected void Application_Start()
{
AreaRegistration.RegisterAllAreas();
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
RouteConfig.RegisterRoutes(RouteTable.Routes);
Initialise();
}
private void Initialise()
{
StartUpException = null;
try
{
Bootstrapper.Initialise();
}
catch (Exception ex)
{
StartUpException = ex;
}
}
然后我在Application_BeginRequest
中有以下代码 protected void Application_BeginRequest(object sender, EventArgs e)
{
if (StartUpException != null)
{
HandleErrorAndRedirect(StartUpException);
HttpRuntime.UnloadAppDomain();
Response.End();
}
}
这有效,但看起来有点像黑客。我也不确定调用UnloadAppDomain的后果,或者如果有多个请求到达会发生什么。有没有更好的方法来管理它?
答案 0 :(得分:3)
我们在App_Start中遇到引导问题,因为没有设置HttpContext,而且一些bootstapped类需要它;无论如何,这也适用于你的情况:
public class MvcApplication : System.Web.HttpApplication {
protected void Application_BeginRequest() {
var context = this.Context;
FirstTimeInitializer.Init(context);
}
private static class FirstTimeInitializer {
private static bool s_IsInitialized = false;
private static Object s_SyncRoot = new Object();
public static void Init(HttpContext context) {
if (s_IsInitialized) {
return;
}
lock (s_SyncRoot) {
if (s_IsInitialized) {
return;
}
// bootstrap
s_IsInitialized = true;
}
}
}
}