asp.net-mvc – MVC动作过滤器集合已修改;枚举操作可能无法执行
我们在MVC 5.1.3应用程序中发生这个错误非常频繁,如果发生这种情况,用户必须刷新该页面,并且它会消失,所以它是间歇性的问题。
我们发现诊断似乎很难在框架本身内发生。任何想法在哪里看? 这是完整的堆栈: System.InvalidOperationException: Collection was modified; enumeration operation may not execute. at System.Collections.Generic.List`1.Enumerator.MoveNextRare() at System.Web.Mvc.FilterProviderCollection.GetFilters(ControllerContext controllerContext,ActionDescriptor actionDescriptor) at System.Web.Mvc.ControllerActionInvoker.GetFilters(ControllerContext controllerContext,ActionDescriptor actionDescriptor) at System.Web.Mvc.Async.AsyncControllerActionInvoker.BeginInvokeAction(ControllerContext controllerContext,String actionName,AsyncCallback callback,Object state) at System.Web.Mvc.Async.AsyncControllerActionInvoker.BeginInvokeAction(ControllerContext controllerContext,Object state) at System.Web.Mvc.Controller.<BeginExecuteCore>b__1c(AsyncCallback asyncCallback,Object asyncState,ExecuteCoreState innerState) at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncVoid`1.CallBeginDelegate(AsyncCallback callback,Object callbackState) at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncResultBase`1.Begin(AsyncCallback callback,Object state,Int32 timeout) at System.Web.Mvc.Async.AsyncResultWrapper.Begin[TState](AsyncCallback callback,Object callbackState,BeginInvokeDelegate`1 beginDelegate,EndInvokeVoidDelegate`1 endDelegate,TState invokeState,Object tag,Int32 timeout,SynchronizationContext callbackSyncContext) at System.Web.Mvc.Controller.BeginExecuteCore(AsyncCallback callback,Object state) at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncResultBase`1.Begin(AsyncCallback callback,SynchronizationContext callbackSyncContext) at System.Web.Mvc.Controller.BeginExecute(RequestContext requestContext,Object state) at System.Web.Mvc.MvcHandler.<BeginProcessRequest>b__4(AsyncCallback asyncCallback,ProcessRequestState innerState) at System.Web.Mvc.Async.AsyncResultWrapper.WrappedAsyncVoid`1.CallBeginDelegate(AsyncCallback callback,SynchronizationContext callbackSyncContext) at System.Web.Mvc.MvcHandler.BeginProcessRequest(HttpContextBase httpContext,Object state) at System.Web.HttpApplication.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() at System.Web.HttpApplication.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() at System.Web.HttpApplication.ExecuteStep(IExecutionStep step,Boolean& completedSynchronously) 之前有一个类似的问题:Collection was modified; enumeration operation may not execute,但这是通过升级到MVC 5解决的,我们已经在5。 解决方法
正如@Erik在评论中所说,显然,在执行请求期间,过滤器的集合被修改,在应用程序启动过程中应该只需要填充它们。
一种可能性是您已经注册了一个定制的IFilterProvider,它打破了代码。这里是发生错误的源代码(来自FilterProviderCollection) for (int i = 0; i < providers.Length; i++) { IFilterProvider provider = providers[i]; foreach (Filter filter in provider.GetFilters(controllerContext,actionDescriptor)) { filters.Add(filter); } } provider.GetFilter(…)返回一个List,稍后在FilterProviderCollection的foreach块中枚举中进行修改。 这是我想到的测试: >首先,确保你没有注册一个自定义的IFilterProvider(你或者你可能正在使用的一个库)。如果是这样,那就是主要嫌犯。>在代码中查找GlobalFilterCollection和GlobalFilters类的所有用法。对此集合的任何修改只能从Global.asax中的Application_Start或启动类(如果您使用OWIN)>寻找您创建过滤器或访问它们的线索。>尝试升级到MVC 5.2。如果这是框架的一个问题(似乎不太可能),这可能会解决它。 (我使用5.2.2.0,在开发或生产中没有看到任何类似的问题)>调试您的应用程序,并在Application_BeginRequest和控制器操作的开头设置一个断点。尝试检查全局过滤器集合,看看是否有任何更改。>也许注册一个自定义IFilterProvider并通过调试或日志检查行为可能会有所帮助。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- asp.net-mvc-3 – 自定义ActionInvoker与MVC 3中
- asp.net – MSVSMON.EXE用VS调试很慢
- 如何避免异常捕获.NET中的复制粘贴
- asp.net-mvc – ASP.NET MVC:围绕控制器分组类
- asp.net-mvc – Asp.Net MVC中的管理区域
- ASP.Net Core Web Api中的异步视频流不起作用
- asp.net-mvc – 使用输出缓存和其他动作过滤器
- asp.net-mvc – 测量时间调用ASP.NET MVC控制器操
- 单元测试 – 如何在ASP MVC 5(Microsoft.AspNet.
- jwt – ASP.NET 5 OAuthBearerAuthentication:以