基于IoC的ControllerActivator
除了通过自定义ControllerFactory的方式引入IoC之外在使用默认DefaultControllerFactory情况下也可以通过一些扩展使基于IoC的Controller激活成为可能不过这就需要我们具体了解实现在DefaultControllerFactory内部的Controller激活机制了
DefaultControllerFactory针对目标Controller的激活其实是通过另一个名为ControllerActivator的组件来完成的所有的ControllerActivator实现了SystemWebMvc IControllerActivator接口如下面的代码片段所示IControllerActivator定义了唯一的用于创建Controller对象的Create方法而DefaultControllerFactory使用的ControllerActivator可以直接通过构造函数参数的方式来指定
public interface IControllerActivator
{
IController Create(RequestContext requestContext Type controllerType)
}
public class DefaultControllerFactory : IControllerFactory
{
//其他成员
public DefaultControllerFactory()
public DefaultControllerFactory(IControllerActivator controllerActivator)
}
实例演示创建基于Ninject的ControllerActivator(S)
如果我们基于一个ControllerActivator对象来创建一个DefaultControllerFactory它最终会被用于Controller对象的激活那么可以通过自定义ControllerActivator的方式将IoC引入Controller激活系统接下来自定义的ControllerActivtor基于另一个IoC框架Ninject较之UnityNinject是一个更加轻量级也更适合ASPNET MVC的IoC框架将自定义的ControllerActivator起名为NinjectControllerActivator如下面的代码所示针对目标Controller的创建是通过一个StandardKernel对象来完成的为了方便实现类型的映射我们定义了一个泛型的Register方法
public class NinjectControllerActivator : IControllerActivator
{
public IKernel Kernel { get; private set; }
public NinjectControllerActivator()
{
thisKernel = new StandardKernel()
}
public IController Create(RequestContext requestContext Type controllerType)
{
return (IController)thisKernelTryGet(controllerType)
}
public void Register<TFrom TTo>() where TTo: TFrom
{
thisKernelBind<TFrom>()To<TTo>()
}
}
接下来我们使用的还是之前演示过的关于员工管理的例子前面我们演示了属性注入的方式在激活EmployeeController的时候对Repository进行初始化现在来演示另一种依赖注入形式构造器注入如下面的代码片段所示只读的Repository是在构造函数中通过指定的参数初始化的而该参数的类型是IEmployeeRepository
[] []