I am trying to use ASP.NET MVC 3 and Ninject 2.2 to insert a registrar object into a custom ActionFilterAttribute attribute.
I can make this work if I tag each controller with a user attribute.
However, I cannot get this to work if I remove the attribute decoration from the controllers and try to use a global action filter.
Here is the code:
in App_Start - NinjectMVC3.cs
using NinjectTest.Abstract; using NinjectTest.Concrete; [assembly: WebActivator.PreApplicationStartMethod(typeof(NinjectTest.App_Start.NinjectMVC3), "Start")] [assembly: WebActivator.ApplicationShutdownMethodAttribute(typeof(NinjectTest.App_Start.NinjectMVC3), "Stop")] namespace NinjectTest.App_Start { using Microsoft.Web.Infrastructure.DynamicModuleHelper; using Ninject; using Ninject.Web.Mvc; public static class NinjectMVC3 { private static readonly Bootstrapper bootstrapper = new Bootstrapper();
}
Global.asax.cs
using System.Web.Routing; using NinjectTest.Attributes; namespace NinjectTest { public class MvcApplication : HttpApplication { public static void RegisterGlobalFilters(GlobalFilterCollection filters) { filters.Add(new TestLoggingAttribute()); filters.Add(new HandleErrorAttribute()); } public static void RegisterRoutes(RouteCollection routes) { routes.IgnoreRoute("{resource}.axd/{*pathInfo}"); routes.MapRoute( "Default",
}
TestLoggingAttribute.cs
using System.Web.Mvc; using Ninject; using NinjectTest.Abstract; namespace NinjectTest.Attributes { public class TestLoggingAttribute : ActionFilterAttribute { [Inject] public ILogger _logger { get; set; } public override void OnActionExecuted(ActionExecutedContext filterContext) { var controller = filterContext.RouteData.Values["controller"]; var action = filterContext.RouteData.Values["action"]; _logger.Info("controller: " + controller + " action: " + action); base.OnActionExecuted(filterContext); } } }
HomeController.cs
using System.Web.Mvc; using NinjectTest.Attributes; namespace NinjectTest.Controllers {
As I said, if I uncomment the [TestLogging] attribute in the controller, it all works. However, I want to use a global filter. Can someone help me?
Ken burkhardt
source share