如何在ASP.Net MVC 2中处理全局异常

时间:2010-04-28 14:22:20

标签: exception-handling asp.net-mvc-2

我的基本控制器有这个覆盖:

protected override void OnException(ExceptionContext filterContext)
{
    // http://forums.asp.net/t/1318736.aspx
    if (filterContext == null)
    {
        throw new ArgumentNullException("filterContext");
    }
    // If custom errors are disabled, we need to let the normal ASP.NET exception handler
    // execute so that the user can see useful debugging information.
    if (filterContext.ExceptionHandled || !filterContext.HttpContext.IsCustomErrorEnabled)
    {
         return;
    }

    Exception exception = filterContext.Exception;

    // If this is not an HTTP 500 (for example, if somebody throws an HTTP 404 from an action method),
    // ignore it.
    if (new HttpException(null, exception).GetHttpCode() != 500)
    {
        return;
    }
}

我想捕获异常并邮寄它。我可以做邮件部分,但不知道如何收集例外?我是MVC的新手。在Web窗体中,我在global.asax

中有这个
void Application_Error(object sender, EventArgs e) 
{
    string AdminEmail = "myEmail@domain";
    // Code that runs when an unhandled error occurs
    Exception objErr = Server.GetLastError().GetBaseException();
    string err = "Error Caught in Application_Error event\n" +
            "Error in: " + Request.Url.ToString() +
            "\n Error Message:" + objErr.Message.ToString() +
            "\n Stack Trace:" + objErr.StackTrace.ToString();
    // Below uses: using System.Diagnostics;
    //EventLog.WriteEntry("Sample_WebApp", err, EventLogEntryType.Error);
    //Server.ClearError(); // Clear error prohibits it from showing on page
    //additional actions...

    MyApp.Utility.Email.Send(AdminEmail, CommonLibrary.FromEmail, "Asp.net Application Error", err);
}

的Web.config

<customErrors mode="On" />

2 个答案:

答案 0 :(得分:2)

您可以查看ELMAH。这是使用ASP.NET MVC的an example

答案 1 :(得分:1)

我认为您需要在基础控制器上的覆盖方法中实现相同的逻辑。像这样:

    protected override void OnException(ExceptionContext filterContext)
    {
        string AdminEmail = "myEmail@domain";
        // Code that runs when an unhandled error occurs
        Exception objErr = filterContext.Exception;
        string err = "Error Caught in Application_Error event\n" +
                "Error in: " + Request.Url.ToString() +
                "\n Error Message:" + objErr.Message.ToString() +
                "\n Stack Trace:" + objErr.StackTrace.ToString();
        // Below uses: using System.Diagnostics;
        //EventLog.WriteEntry("Sample_WebApp", err, EventLogEntryType.Error);
        //Server.ClearError(); // Clear error prohibits it from showing on page
        //additional actions...

        MyApp.Utility.Email.Send(AdminEmail, CommonLibrary.FromEmail, "Asp.net Application Error", err);
        base.OnException(filterContext);
    }