c#-MVC3中的Ninject依赖注入-控制器外部
作者:互联网
我们在MVC3项目中使用Ninject进行依赖项注入.
我使用NuGet将软件包引用添加到Ninject和Ninject.MVC3软件包.当我这样做时,它在我的App_Start文件夹中创建了一个NinjectMVC3类:
public static class NinjectMVC3
{
private static readonly Bootstrapper bootstrapper = new Bootstrapper();
public static void Start()
{
DynamicModuleUtility.RegisterModule(typeof(OnePerRequestModule));
DynamicModuleUtility.RegisterModule(typeof(HttpApplicationInitializationModule));
bootstrapper.Initialize(CreateKernel);
}
public static void Stop()
{
bootstrapper.ShutDown();
}
private static IKernel CreateKernel()
{
var kernel = new StandardKernel();
RegisterServices(kernel);
return kernel;
}
private static void RegisterServices(IKernel kernel)
{
kernel.Bind<IPrincipal>().ToMethod(c => HttpContext.Current.User);
}
}
到目前为止,这对于解决我的控制器中的依赖关系非常有效:
public class HomeController : Controller {
protected IPrincipal principal { get; set; }
public HomeController(IPrincipal principal) {
this.principal = principal;
}
}
该控制器对IPrincipal具有依赖性,我已经在我的引导程序类中设置了IPrincipal以解析为HttpContext.Current.User.我还有另一个依赖IPrincipal而不是控制器的类:
public class NonControllerClass
{
protected IPrincipal Principal { get; set; }
public NonControllerClass(IPrincipal principal) {
}
}
我将如何解决这种依赖性?如果它不是构造函数的参数,我该怎么办?
}
解决方法:
好吧,理想情况下这应该永远不是问题.所有依赖项都应插入到您的控制器中,并且这些依赖项所依赖的任何依赖项也应自动注入.
在MVC中,(几乎)一切都从控制器开始.所以你可能有:
public class HomeController : Controller {
protected IMyService myService { get; set; }
public HomeController(IMyService myService) {
this.myService = myService;
}
}
public class MyService {
protected IPrincipal principal;
public MyService(IPrincipal principal) { this.principal = principal)
}
请注意,您无需执行任何操作,因为服务已注入到控制器中,所以服务会自动注入正确的依赖项.
但是,有时可能需要动态创建对象.在这种情况下,您可以使用MVC DependencyResolver.
var principal = DependencyResolver.Current.GetService<IPrincipal>();
但是,除非绝对必要,否则应避免这样做,因为这被认为是反模式(称为服务位置).有时候,您别无选择.
如果您不想使用构造函数注入,则可以使用属性注入.
public class MyService {
[Inject]
public IPrincipal principal {get; set;}
}
标签:dependency-injection,ninject,c,net,asp-net-mvc 来源: https://codeday.me/bug/20191202/2085940.html