我按照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());
}
答案 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);
}
}