我的项目使用通常的存储库模式与服务和工作单元(所有与Ninject注入来自NinjectModule的依赖项),但我正在尝试从ActionFilterAttribute访问一个服务,从而注入一些信息(来自数据库)我显示的页面的布局,所以我不需要搞乱每个控制器上的所有操作.
当我在一个屏幕上保存到DB然后移动到下一个然后返回到前一个(使用标准的@ Url.Action)时出现问题:索引操作的ActionFilterAttribute被触发但是对服务和相应的存储库的调用(在属性中)抛出异常,因为已经处理了DbContext.
访问服务时是否有任何问题,因此,在通过Property Injection注入服务时,来自ActionFilterAttribute的DbContext?我想要注意我在属性中使用属性注入服务,因为构造函数接收2个参数,这些参数是任意的,具体取决于Action方法的签名,所以我唯一的选择是注入via属性.
如果您需要一些代码,请告诉我,我会更新问题.
解决方法
我在以下问题中找到了解决问题的方法:
Injecting dependencies into ASP.NET MVC 3 action filters. What’s wrong with this approach?
Injecting dependencies into ASP.NET MVC 3 action filters. What’s wrong with this approach?
结合Mark Seeman的回答和striplingwarrior的评论是解决方案.
基本上我将我的ActionFilterAttribute拆分为一个仅仅装饰我的Actions并保留我以后需要的参数的属性,还有一个ActionFilter,它检查了Action的自定义属性,如果我的属性存在,那么它将我想要的数据从DB注入ViewBag.之后所有内容都与Ninject的BindFilter扩展名绑定,因此它仅适用于它所需的方法.