将服务注入过滤器

时间:2015-06-23 13:22:16

标签: c# asp.net-mvc dependency-injection ninject ninject.web.mvc

我按照Ninject-Wiki上的教程进行操作 它让我疯了,过滤器内的服务为空并且不会更改为对象实例。我尝试了属性注入并使用[Inject] -attribute修饰了界面 - 没有结果。 我尝试通过构造函数注入注入(如下所示) - 过滤器甚至没有被击中!我想使用这种模式: - (

请为上帝的爱(以及我的理智)帮助我解决这个问题!

祝你好运

我有一个" BaseController",它作为我所有控制器的中央基类。它使用" MyExceptionLog" -Attribute。

进行修饰
[MyExceptionLog]
public class BaseController : Controller
{
   //omitted for brevity
}

" MyExceptionLog"只是一个标记控制器的空类。它继承自FilterAttribute。 我希望注入服务的过滤器如下所示:

public class MyExceptionLogFilter:ActionFilterAttribute
{
    private readonly ILogger Logger;
    public MyExceptionLogFilter(ILogger logger)
    {
        Logger = logger;
    }

    public override void  OnActionExecuted(ActionExecutedContext filterContext)
    {
        if (filterContext.Exception != null)
        {
            Logger.Log(nameof(filterContext.Controller), filterContext.Exception, null);
            if (filterContext.Exception.InnerException != null)
            {
                Logger.Log(nameof(filterContext.Controller), filterContext.Exception.InnerException, null);
            }
        }
    }
}

我使用customControllerFactory将服务注入我的控制器:

public class NinjectControllerFactory : DefaultControllerFactory
{
    public IKernel kernel;

    public NinjectControllerFactory()
    {
        kernel = new StandardKernel();
        AddBindings(); 
    }

    private void AddBindings()
    {
        kernel.Bind<IDbRepository>().To<DbRepository>();
        kernel.Bind<ILogger>().To<EntLibLogger>();
        kernel.BindFilter<MyExceptionLogFilter>(FilterScope.Action, 0).WhenControllerHas<MyExceptionLogAttribute>();
    }

    protected override IController GetControllerInstance(System.Web.Routing.RequestContext requestContext, Type controllerType)
    {
        return controllerType == null
            ? null
            : (IController)kernel.Get(controllerType);
    }
}

最后我在我的Global.Asax.cs中注册了controllerFactory

protected void Application_Start()
{
    AreaRegistration.RegisterAllAreas();
    FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
    RouteConfig.RegisterRoutes(RouteTable.Routes);
    BundleConfig.RegisterBundles(BundleTable.Bundles);

    ControllerBuilder.Current.SetControllerFactory(new NinjectControllerFactory());
}

1 个答案:

答案 0 :(得分:0)

我遇到了类似的问题。通过将服务注入我的基本api控制器类,我能够绕过它。

示例:

public class BaseApiController : ApiController
{
     private readonly ILogger _logger;

     public BaseApiController(ILogger logger)
     {
        _logger = logger;
     }

     protected override void Initialize(HttpControllerContext controllerContext)
      {
         _logger.log("somes stuff");
         base.Initialize(controllerContext);
      }

}