使用Autofac IOC组织多项目应用程序

简介:

较复杂的应用程序都是由多个项目组织成的,项目可以划分成程序集(Assemblies)和宿主(Hosts),也就是应用程序的入口。

Assemblies 通常是常见的类库项目,包括可以重用的功能和方便测试,通常包括下面的组件:

  • Views, Controllers 和 Models
  • 服务
  • 持久类 和 repositories
  • Decorators
  • Reusable user controls
  • 规则库
  • 业务逻辑
    这些项目通常不应该直接依赖于下面的组件:
  • IoC 容器程序集;
  • 日志记录框架 ;
  • 数据访问框架;
  • 其他第三方类库.

为了分离这些逻辑,我们可以定义一些接口,然后通过配置代码将具体实现关联起来,例如日志记录我们可以定义一个接口ILog,生产环境下我们可以把它改成用Apache log4net或者企业类库的日志记录模块都可以。由于这是接口定义和实现分离的,我们可以在不同环境下使用不同的实现,只需要通过配置修改就可以而不要重新编译代码。

Hosts代表应用程的入口,有下面这些形式:

  • 桌面应用程序:
  • Windows.Forms;
  • WPF;
  • 控制台应用程序;
  • windows 服务;
  • Web应用程序
  • Microsoft Office Add-Ins;
  • Microsoft Azure Roles.

Host负责构建应用程环境(上下文),并把它传递给应用程序的入口,在IOC容器方面来说,通过配置容器中的应用程序组件,获取Shell类并运行。通常Host项目都很小,主要完成两个方面的工作:配置容器和调用Shell.Run()。

用Autofac的Host的伪代码类似于

var builder = new ContainerBuilder(); 
builder.Register(new ConfigurationSettingsReader()); 
using (var container = builder.Build()) 
{ 
   var shell = container.Resolve<Shell>(); 
   shell.Execute(); 
}

上述代码中new ConfigurationSettingsReader()就是autofac从配置文件中读取相关的组件配置,一般使用XML文件进行配置,autofac的xml配置文档可以看XmlConfiguration,使用配置文件也有缺点:

不是强类型的,编译器无法发现错误,没有智能提示
配置文件会变得越来越大
维护多个配置文件比较困难
文件文件不适合用于复杂的环境
上述缺点我们可以通过.NET代码块封装相关的配置细节,在XML文件中只保留粗粒度的配置,Autofac可以通过Module进行配置块的封装,具体可以参考文档StructuringWithModules。

我这里取个例子:

public  class LoggingModule : Module 
   { 
       public Mode Mode { get; set; } 
       public static string EventLogName = "网站通行证"; 
       public static string EventLogSource = "应用程序";

       public LoggingModule() 
       { 
           Mode = NCASService.Mode.Diagnostics; 
       }

       protected override void Load(ContainerBuilder builder) 
       { 
           // configure logging  
           var logger = GetLoggerForWindows(Mode);    
           builder.RegisterInstance(logger);   
           builder.RegisterInstance(logger.Get("DefaultLog")); 
           base.Load(builder); 
       }

       static INamedProvider<ILog> GetLoggerForWindows(Mode mode) 
       {  // configuring different logging based on our mode 
           switch (mode) 
           { 
               case Mode.Release: 
                   // write all informational and higher events to indows event log 
                   LoggingStack.UseEventLog(EventLogName, EventLogSource) 
                       .Filter(LogLevel.Info, LogLevel.Max); 
                   // dump all warning and higher messages to rolling text log   
                   LoggingStack.UseRollingLog(@"logs\errorlog.txt", 100.Kb(), 10) 
                       .Filter(LogLevel.Warn, LogLevel.Fatal); 
                   break; 
               case Mode.Diagnostics: 
                   // dump all messages to daily log 
                   LoggingStack.UseDailyLog(@"log.txt"); 
                   break; 
               case Mode.Debug: 
                   // Visual studio would get these messages  
                   return TraceLog.Provider; 
               default: 
                   throw new ArgumentOutOfRangeException("mode"); 
           } 
           return LoggingStack.GetLogProvider(); 
       }

上述是把我们的日志模块的配置用代码进行配置,我们的XML配置文件中的配置就会变得很简单:

<!-- Production configuration -->
<module type="NdonFramework.NCASService.LoggingModule, NCASService">
</module>

<!-- Development configuration -->
<module type="NdonFramework.NCASService.LoggingModule, NCASService">
  <properties>
    <property name="Mode" value="Debug" />

  </properties>
</module>  

<!-- Sandbox configuration -->
<module type="NdonFramework.NCASService.LoggingModule, NCASService">
  <properties>
    <property name="Mode" value="Diagnostics" />
  </properties>
</module>

使用模块组织不同程序集中的组件注册到容器里,模块我一般需要配置以下内容:

配置日志记录并注册ILog组件(例如记录到控制台,文本文件、Windows日志文件)

  • 配置异常处理策略
  • 注册数据访问类
  • 注册交叉关注点
  • 配置验证规则
  • 通过Autofac的Module分解项目组件间的复杂关系。

本文来自云栖社区合作伙伴“doNET跨平台”,了解相关信息可以关注“opendotnet”微信公众号

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
10天前
|
Java 大数据 云计算
Spring框架:Java后台开发的核心
【4月更文挑战第15天】Spring框架在Java后台开发中占据核心位置,因其控制反转(IoC)、面向切面编程(AOP)、事务管理等特性提升效率和质量。Spring提供数据访问集成、RESTful Web服务和WebSocket支持。优势包括高效开发、灵活扩展、强大生态圈和广泛应用。应用于企业级应用、微服务架构及云计算大数据场景。掌握Spring对Java开发者至关重要。
|
12天前
|
前端开发 Java 容器
家族传承:Spring MVC中父子容器的搭建与管理指南
家族传承:Spring MVC中父子容器的搭建与管理指南
26 3
|
6月前
|
XML 存储 前端开发
“实战经验总结:构建灵活、可维护的自定义MVC应用程序”(上)
“实战经验总结:构建灵活、可维护的自定义MVC应用程序”
32 0
|
6月前
|
存储 设计模式 前端开发
“实战经验总结:构建灵活、可维护的自定义MVC应用程序”(下)
“实战经验总结:构建灵活、可维护的自定义MVC应用程序”
21 0
|
6月前
|
安全 Java Go
Spring安全配置: 构建安全稳固的Java应用
Spring安全配置: 构建安全稳固的Java应用
41 0
|
8月前
|
安全 Java 数据安全/隐私保护
Spring框架核心功能介绍(一)
Spring框架核心功能介绍(一)
129 0
|
11月前
|
XML 设计模式 Java
【框架源码】手写Spring框架IOC容器核心流程
【框架源码】手写Spring框架IOC容器核心流程
【框架源码】手写Spring框架IOC容器核心流程
|
前端开发 安全 Java
spring的七大模块和使用spring框架的七种好处
目录 Spring框架模块: 1、核心容器(Core) 2、AOP模块 3、对象/关系映射集成模块ORM 4、JDBC抽象和DAO模块 5、Spring的Web模块 6、应用上下文(Context)模块 7、Spring的MVC框架 spring框架的好处: 第一: 非侵入式设计 第二:支持AOP 第三:支持声明式事务处理 第四:方便集成各种优秀框架 第五:降低Java EE API的使用难度 第六:方便解耦、简化开发 第七:方便程序的测试
190 0
Spring框架核心及设计思想
Spring框架核心及设计思想
101 0
Spring框架核心及设计思想
|
开发框架 自动驾驶 前端开发
使用Spring框架能带来哪些好处?
使用Spring框架能带来哪些好处?
使用Spring框架能带来哪些好处?