为什么我的MVC4 HandleErrorAttribute不起作用?

时间:2013-10-02 17:09:46

标签: asp.net-mvc-4

我正在将MVC3 Web项目转换为MVC4。我创建了一个继承自HandleErrorAttribute的ElmahHandleErrorAttribute,它在MVC3中运行良好,并且在我的本地开发机器上工作正常,但它在测试环境中抛出以下异常......

[InvalidOperationException: The given filter instance must implement one or more of the following filter interfaces: IAuthorizationFilter, IActionFilter, IResultFilter, IExceptionFilter.]
   System.Web.Mvc.GlobalFilterCollection.ValidateFilterInstance(Object instance) +110
   System.Web.Mvc.GlobalFilterCollection.AddInternal(Object filter, Nullable`1 order) +17
   System.Web.Mvc.GlobalFilterCollection.Add(Object filter) +12
   Home2Me.MvcApplication.RegisterGlobalFilters(GlobalFilterCollection filters) in c:\###\Home2Me\Global.asax.cs:16
   Home2Me.MvcApplication.Application_Start() in c:\###\Home2Me\Global.asax.cs:118

[HttpException (0x80004005): The given filter instance must implement one or more of the following filter interfaces: IAuthorizationFilter, IActionFilter, IResultFilter, IExceptionFilter.]
   System.Web.HttpApplicationFactory.EnsureAppStartCalledForIntegratedMode(HttpContext context, HttpApplication app) +9249709
   System.Web.HttpApplication.RegisterEventSubscriptionsWithIIS(IntPtr appContext, HttpContext context, MethodInfo[] handlers) +131
   System.Web.HttpApplication.InitSpecial(HttpApplicationState state, MethodInfo[] handlers, IntPtr appContext, HttpContext context) +194
   System.Web.HttpApplicationFactory.GetSpecialApplicationInstance(IntPtr appContext, HttpContext context) +339
   System.Web.Hosting.PipelineRuntime.InitializeApplication(IntPtr appContext) +253

[HttpException (0x80004005): The given filter instance must implement one or more of the following filter interfaces: IAuthorizationFilter, IActionFilter, IResultFilter, IExceptionFilter.]
   System.Web.HttpRuntime.FirstRequestInit(HttpContext context) +9164336
   System.Web.HttpRuntime.EnsureFirstRequestInit(HttpContext context) +97
   System.Web.HttpRuntime.ProcessRequestNotificationPrivate(IIS7WorkerRequest wr, HttpContext context) +256

这门课没什么特别之处。它非常接近Elmah的标准版。

public class ElmahHandleErrorAttribute : System.Web.Mvc.HandleErrorAttribute
{

    /// <summary>
    /// Called when an exception occurs.
    /// </summary>
    /// <param name="context"></param>
    public override void OnException(ExceptionContext context)
    {
        base.OnException(context);
        if (!context.ExceptionHandled) return; // if unhandled, will be logged anyhow
        var e = context.Exception;
        HandleException(e);
    }

... (code snipped for brevity) ...

}

以下是在Global.asax.cs中注册过滤器的代码......

public static void RegisterGlobalFilters(GlobalFilterCollection filters)
{
    filters.Add(new ElmahHandleErrorAttribute());
}

过滤器在单独的程序集中定义,该程序集也更新为MVC4。我有多个使用此过滤器的项目。其中一个在测试环境中工作正常,另一个也有同样的问题。

关于可能出错的任何想法?我相信所有MVC3引用都已在项目中正确更新,包括root和views目录中的web.config文件。它在本地工作,我卸载了MVC3并删除了所有“额外的”MVC3 dll。

1 个答案:

答案 0 :(得分:0)

我相信我找到了答案。我在根web.config文件中添加了一个运行时部分,以将MVC3引用转换为MVC4。

<configuration>
    ... (snipped for brevity) ...
    <runtime>
        <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
            <dependentAssembly>
                <assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" />
                <bindingRedirect oldVersion="1.0.0.0-4.0.0.0" newVersion="4.0.0.0" />
            </dependentAssembly>
        </assemblyBinding>
    </runtime>
</configuration>

我宁愿修复引用MVC3的任何内容,但我无法弄清楚它可能是什么。现在这必须是一个足够好的答案。