NopCommerce架构分析之一----依赖类生成容器

摘要:
为了实现松散耦合框架设计的目的,NopCommerce使用IOC框架:Autofac。IOC的封装和灵活使用机制主要封装在Nop.Core.Infrastructure中。在Autofac中,对象也称为组件。ITypeFinder及其实现类如下:4。类型注册容器管理类:ContainerManager,它管理通过Autofac生成的容器;ContainerConfigurer:ContainerConfigurer:配置依赖项反转容器,并建立整个框架的类型依赖项注册和类型查找类之间的关系。系统的默认引擎是NopEngine。如果未配置有效的引擎,则使用默认引擎。生成的引擎保存在单例容器中。

NopCommerce为了实现松耦合的框架设计目的,使用了IOC框架:Autofac。据有人测试,Autofac是性能好的IOC工具

1、在IOC中,组件首先需要在IOC中注册,有通过配置文件注册的,像Spring.net,也有通过特性注册的,像StructureMap,也有通过代理来注册的,像Autofac。但是IOC讲究一个原则,就是接口和实现分离。所有IOC就是生命某个具体类实现了某个接口。然后在使用时,系统从IOC中获取接口的实现类,并创建对象。

2、下面来看NopCommerce如何使用Autofac实现松耦合的框架设计的。其实它的插件机制也是通过Autofac来实现的。

IOC的封装及灵活使用机制主要在Nop.Core.Infrastructure中封装的。在Autofac中,对象又称为组件。组件生命周期分为:单例、临时和生命周期域内,如下定义:

[html] view plain copy
 
  1. namespace Nop.Core.Infrastructure.DependencyManagement  
  2. {  
  3.     public enum ComponentLifeStyle  
  4.     {  
  5.         Singleton = 0,  
  6.         Transient = 1,  
  7.         LifetimeScope = 2  
  8.     }  
  9. }  

Autofac中有容器、并提供方法注册接口及其类型,还提供方法查找到注册的类型,以及自动创建对象。

3、类型查找器

为了支持插件功能,以及支持一些自动注册的功能。系统提供了类型查找器。ITypeFinder以及实现类就是提供此功能。通过类型查找器可以查找本程序域中的类,也可以查找整个bin目录下所有动态链接库中类,并把它们注册到类型反转容器中。ITypeFinder以及实现类如下:

4、类型注册

容器管理类:ContainerManager,管理通过Autofac生成的容器;

容器配置器:ContainerConfigurer:配置依赖反转容器,建立整个框架的类型依赖注册和类型查找类之间的关系。

在系统中有一个依赖类引擎上下文环境:EngineContext,可以根据配置文件生成引擎,此引擎是负责根据类型接口从容器中返回对象。

系统默认引擎NopEngine,若没有配置有效的引擎,即用默认引擎,生成的引擎保存在单例容器中。

它们的关系如下:

系统在类MvcApplication的方法Application_Start中初始化引擎上下文。并通过调用EngineContext.Initialize(false);实现所有反转依赖的注册功能;

5、容器注册类

系统注册接口为:IDependencyRegistrar,系统通过ContainerConfigurer注册此接口以及实现类的,并通过ITypeFinder类搜寻程序集里实现接口IDependencyRegistrar的类。代码如下:

[csharp] view plain copy
 
  1. namespace Nop.Core.Infrastructure.DependencyManagement  
  2. {  
  3.     /// <summary>  
  4.     /// Configures the inversion of control container with services used by Nop.  
  5.     /// </summary>  
  6.     public class ContainerConfigurer  
  7.     {  
  8.         public virtual void Configure(IEngine engine, ContainerManager containerManager, EventBroker broker, NopConfig configuration)  
  9.         {  
  10.             //other dependencies  
  11.             containerManager.AddComponentInstance<NopConfig>(configuration, "nop.configuration");  
  12.             containerManager.AddComponentInstance<IEngine>(engine, "nop.engine");  
  13.             containerManager.AddComponentInstance<ContainerConfigurer>(this, "nop.containerConfigurer");  
  14.   
  15.             //type finder  
  16.             containerManager.AddComponent<ITypeFinder, WebAppTypeFinder>("nop.typeFinder");  
  17.   
  18.             //register dependencies provided by other assemblies  
  19.             var typeFinder = containerManager.Resolve<ITypeFinder>();  
  20.             containerManager.UpdateContainer(x =>  
  21.             {  
  22.                 var drTypes = typeFinder.FindClassesOfType<IDependencyRegistrar>();  
  23.                 var drInstances = new List<IDependencyRegistrar>();  
  24.                 foreach (var drType in drTypes)  
  25.                     drInstances.Add((IDependencyRegistrar)Activator.CreateInstance(drType));  
  26.                 //sort  
  27.                 drInstances = drInstances.AsQueryable().OrderBy(t => t.Order).ToList();  
  28.                 foreach (var dependencyRegistrar in drInstances)  
  29.                     dependencyRegistrar.Register(x, typeFinder);  
  30.             });  
  31.   
  32.             //event broker  
  33.             containerManager.AddComponentInstance(broker);  
  34.         }  
  35.     }  
  36. }  


而接口IDependencyRegistrar的内容如下:

[csharp] view plain copy
 
  1. namespace Nop.Core.Infrastructure.DependencyManagement  
  2. {  
  3.     public interface IDependencyRegistrar  
  4.     {  
  5.         /// <summary>  
  6.         /// 此方法在通过ContainerBuilder注册依赖关系。  
  7.         /// </summary>  
  8.         /// <param name="builder">容器管理者类</param>  
  9.         /// <param name="typeFinder">类型查找者接口</param>  
  10.         void Register(ContainerBuilder builder, ITypeFinder typeFinder);  
  11.         /// <summary>  
  12.         /// 注册排序序号  
  13.         /// </summary>  
  14.         int Order { get; }  
  15.     }  
  16. }  



6、单例类容器

单例类系列保存系统中与程序相同生命周期的单例对象,或者叫做单例类容器。

其中包括实体类,集合类和字典类的单例容器。

Singleton<T>,SingletonList<T>,SingletonDictionary<TKey, TValue>。EngineContext就是通过Singleton<T>类来管理引擎的。

7、MVC 服务提供类。

类型依赖获取器:NopDependencyResolver,通过继承mvc下的接口:IDependencyResolver,并在Application_Start方法中注册,使之在系统启动时调用。

[csharp] view plain copy
 
  1. //set dependency resolver  
  2.             var dependencyResolver = new NopDependencyResolver();  
  3.             DependencyResolver.SetResolver(dependencyResolver);  



8、其他

事件拦截类:EventBroker:过滤向系统发送的请求,防止由于临时的错误或异常导致系统崩溃。

系统启动时执行任务:IStartupTask,启动时执行的任务主要是数据库的初始化和加载。

免责声明:文章转载自《NopCommerce架构分析之一----依赖类生成容器》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇用ArcEngine的工具条添加图层要素c++学习笔记——字面值常量类下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

k8s-pod

介绍 1、pod 是k8s 中的最小部署单元,一个pod 可以运行多个容器,也可以运行一个容器。 2、pod 相比于容器,通过pod把容器包装到其中,通过k8s管理,可以实现负载均衡、高可用的特性(pod 中容器进程挂掉,应用程序异常主动通知k8s,通过健康检查检测程序异常,集群节点挂掉等都可以重新创建pod或者迁移pod,而容器不具备上述特性。 pod...

java函数式编程

1.函数式接口 1.1概念:java中有且只有一个抽象方法的接口。 1.2格式: 修饰符 interface接口名称 { public abstract返回值类型 方法名称(可选参数信息); //其他非抽象方法内容 } //或者 public interfaceMyFunctionalInterface { voidmyMethod(); }...

eNSP——Hybrid接口的应用

原理: Hybrid接口既可以连接普通终端的接入链路又可以连接交换机间的干道链路,它允许多个VLAN的帧通过,并可以在出接口方向将某些VLAN帧的标签剥掉。 Hybrid接口处理VLAN帧的过程如下: (1)收到一个二层帧,判断是否有VLAN标签。没有标签,则标记上Hybrid接口的PVID,进行下一-步处理;有标签,判断该Hybrid接口是否允许该VLA...

笔记本中LVDS屏与eDP屏的比较

 LVDS,即Low Voltage Differential Signaling,是一种低压差分信号技术接口。它是美国NS公司(美国国家半导体公司)为克服以TTL电平方式传输宽带高码率数据时功耗大、EMI电磁干扰大等缺点而研制的一种数字视频信号传输方式。随着显示分辨率的越来越高,LVDS面对高分辨率的显示越来越吃力,传统的VGA、DVI等接口逐渐不能满足...

[转]C/C++实现回调机制的几种方式(回调、槽、代理)

转自:https://www.jianshu.com/p/4f907bba6d5f (1)Callback方式(回调) Callback的本质是设置一个函数指针进去,然后在需要需要触发某个事件时调用该方法, 比如Windows的窗口消息处理函数就是这种类型。比如下面的示例代码,我们在Download完成时需要触发一个通知外面的事件: #include...

学习设计模式之适配器模式

适配器模式 将一个类的接口转换成客户希望的另外一个接口。Adapter 模式使得原本由于接口不兼容而不能一起工作的那些类可以一起工作。 Adapter 模式的宗旨:保留现有类所提供的服务,向客户提供接口,以满足客户的期望。 首先应该明白一点,适配器是最后的补救措施,应该在功能设计的时候尽量避免。所以请在设计功能的时候忘掉这个模式。 类结构图Target 用户...