較復(fù)雜的應(yīng)用程序都是由多個項(xiàng)目組織成的,項(xiàng)目可以劃分成程序集(Assemblies)和宿主(Hosts),也就是應(yīng)用程序的入口。
Assemblies 通常是常見的類庫項(xiàng)目,包括可以重用的功能和方便測試,通常包括下面的組件:
這些項(xiàng)目通常不應(yīng)該直接依賴于下面的組件:
為了分離這些邏輯,我們可以定義一些接口,然后通過配置代碼將具體實(shí)現(xiàn)關(guān)聯(lián)起來,例如日志記錄我們可以定義一個接口ILog,生產(chǎn)環(huán)境下我們可以把它改成用Apache log4net或者企業(yè)類庫的日志記錄模塊都可以。由于這是接口定義和實(shí)現(xiàn)分離的,我們可以在不同環(huán)境下使用不同的實(shí)現(xiàn),只需要通過配置修改就可以而不要重新編譯代碼。
Hosts代表應(yīng)用程的入口,有下面這些形式:
Host負(fù)責(zé)構(gòu)建應(yīng)用程環(huán)境(上下文),并把它傳遞給應(yīng)用程序的入口,在IOC容器方面來說,通過配置容器中的應(yīng)用程序組件,獲取Shell類并運(yùn)行。通常Host項(xiàng)目都很小,主要完成兩個方面的工作:配置容器和調(diào)用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從配置文件中讀取相關(guān)的組件配置,一般使用XML文件進(jìn)行配置,autofac的xml配置文檔可以看XmlConfiguration,使用配置文件也有缺點(diǎn):
不是強(qiáng)類型的,編譯器無法發(fā)現(xiàn)錯誤,沒有智能提示
配置文件會變得越來越大
維護(hù)多個配置文件比較困難
文件文件不適合用于復(fù)雜的環(huán)境
上述缺點(diǎn)我們可以通過.NET代碼塊封裝相關(guān)的配置細(xì)節(jié),在XML文件中只保留粗粒度的配置,Autofac可以通過Module進(jìn)行配置塊的封裝,具體可以參考文檔StructuringWithModules。
我這里取個例子:
public class LoggingModule : Module
{
public Mode Mode { get; set; }
public static string EventLogName = "網(wǎng)站通行證";
public static string EventLogSource = "應(yīng)用程序";
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();
}
上述是把我們的日志模塊的配置用代碼進(jìn)行配置,我們的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>
使用模塊組織不同程序集中的組件注冊到容器里,模塊我一般需要配置以下內(nèi)容:
通過Autofac的Module分解項(xiàng)目組件間的復(fù)雜關(guān)系。
聯(lián)系客服