如何为asp.net mvc提供Ninject和Filter属性的依赖注入?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (13)

我正在为asp.net mvc 3编写一个自定义的授权过滤器。我需要向该类中注入一个用户服务,但我不知道如何执行此操作。

public class AuthorizeAttribute : FilterAttribute, IAuthorizationFilter
{
    private IUserService userService;
    private string[] roles;

    public AuthorizeAttribute(params string[] roles)
    {
        this.roles = roles;
    }

    public void OnAuthorization(AuthorizationContext filterContext)
    {
        throw new NotImplementedException();
    }
}

我正在使用ninject进行依赖注入。我不想使用工厂或服务定位器模式。

我的绑定在global.acsx中看起来像这样:

    internal class SiteModule : NinjectModule
    {
        public override void Load()
        {
            Bind<IUserService>().To<UserService>();
        }
    }
提问于
用户回答回答于

如果你想使用构造函数注入,那么你需要创建一个属性和一个过滤器。

///marker attribute
public class MyAuthorizeAttribute : FilterAttribute { }

//filter
public class MyAuthorizeFilter : IAuthorizationFilter
{
      private readonly IUserService _userService;
      public MyAuthorizeFilter(IUserService userService)
      {
          _userService = userService;
      }

      public void OnAuthorization(AuthorizationContext filterContext)
      {
          var validUser = _userService.CheckIsValid();

          if (!validUser)
          {
              filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary { { "action", "AccessDenied" }, { "controller", "Error" } });
          }
      }
}

捆绑:

this.BindFilter<MyAuthorizeFilter>(System.Web.Mvc.FilterScope.Controller, 0).WhenControllerHas<MyAuthorizeAttribute>();

控制器:

[MyAuthorizeAttribute]
public class YourController : Controller
{

}
用户回答回答于

不要使用[Inject]!

我使用了像Darin Dimitrov所说的[Inject],它可能会导致在高负载,高争用情况下与.InRequestScope一起导致线程问题。

BZ的方式也是在维基上,我看到许多地方,这是正确的方式来做到这一点

https://github.com/ninject/ninject.web.mvc/wiki/Filter-configurations

扫码关注云+社区