Abp是一個基於模塊化開發的應用程式框架,提供了模塊化基礎的架構和模塊化載入的引擎。 理解模塊 一個模塊是對一個功能點的封裝,可以獨立成為一個包,實現了松耦合的代碼組織方式。Abp框架的基本思想就是模塊開發,模塊就想樂高中的一塊塊積木,在項目中將不同功能點的模塊引用進來,就像搭積木一樣構建成一個成品 ...
Abp是一個基於模塊化開發的應用程式框架,提供了模塊化基礎的架構和模塊化載入的引擎。
理解模塊
一個模塊是對一個功能點的封裝,可以獨立成為一個包,實現了松耦合的代碼組織方式。Abp框架的基本思想就是模塊開發,模塊就想樂高中的一塊塊積木,在項目中將不同功能點的模塊引用進來,就像搭積木一樣構建成一個成品。
模塊化的實現
通過在一個程式集中,創建一個模塊類,繼承AbpModule類,就可以很簡單的將這個程式集作為Abp框架中的一個模塊。如下麵的代碼,就是一個模塊類的定義。
[DependsOn(
typeof(AbpAutoMapperModule),
typeof(AbpDddApplicationModule),
typeof(AbpObjectExtendingModule)
)]
public class BaseApplicationModule : AbpModule
{
public override void ConfigureServices(ServiceConfigurationContext context)
{
Configure<AbpAutoMapperOptions>(options =>
{
options.AddMaps<BaseApplicationModule>();
});
}
public override void OnApplicationInitialization(ApplicationInitializationContext context)
{
base.OnApplicationInitialization(context);
}
}
AbpModule是 abp框架的模塊基礎類,一個類庫可以通過一個繼承此類的類,聲明為一個模塊。通過對AbpModule類的查看,可以看到這是一個抽象類,它很好的遵循了介面隔離原則。
一個模塊就是一個完整的功能點,往往需要對其依賴的一些東西進行配置,如資料庫連接、如配置文件讀取等。Abp引擎通過將.net Core管道和容器傳遞,使得模塊中可以配置自己的依賴註入和請求管道,而不需要在外部使用的時候添加一大堆配置,這樣就達到了獨立開放,開箱即用的目的。
通過重寫PreConfigureServices
、ConfigureServices
、PostConfigureServices
這三個方法,可以在模塊內部完成該模塊的依賴註入配置。通過重寫OnPreApplicationInitialization
、OnApplicationInitialization
、OnPostApplicationInitialization
、OnApplicationShutdown
這四個方法可完成模塊在應用程式生命周期中的配置,在應用程式啟動或者停止的時候做一些操作,也可以對asp.net Core的請求管道進行操作,例如加入自己的中間件。這些方法大家也並不陌生,和Asp.net Core中Startup類中的方法類似。
模塊之間可以引用,並且設置模塊的依賴關係,一個模塊載入時,會先載入其依賴的模塊。通過DependsOnAttribute可以指定模塊依賴的模塊,形成一個依賴鏈,Abp引擎啟動時載入模塊時,會先載入依賴模塊。
Volo.Abp.Core 核心包
Volo.Abp.Core是Abp框架的核心包,關於Abp模塊化的實現都在這個包中,我們可以通過對這個包的源碼的研究,看下Abp模塊化的實現方式。
首先,從Volo.Abp.Core的源碼中,可以看到這個包也依賴於一些第三方包。
Fody: 可以在編譯過程中攔截vs行為,動態地將一些代碼添加到dll中,實現靜態AOP的功能。
JetBrains: 提供一些數據標識,可以在編譯期間對參數進行檢查,減少bug
Nito:能夠在使用Lock排他鎖的時候,使用await非同步的方式
SoureLink:支持在安裝nuget包之後,動態地從git中下載源碼以供調試,需要在vs中設置啟用源程式調試
System.Collection.Immutable: 不可變集合,不可以往集合add
System.Linq.Dynamic.Core:動態linq,將強類型的Linq表達式變成字元串的方式進行操作
模塊載入過程
ABP框架的啟動過程,最根本的就是模塊的裝載過程。
眾所周知,asp.net core程式的啟動類時startup類,而在abp框架中,startup類卻很簡單,雖然代碼簡單,但是這兩個方法卻不簡單,正是通過這兩個方法,將asp.net core中的請求轉移到abp框架中來處理。
以AddApplication<TStartupModule>()
擴展方法作為入口,通過查看源碼,可以看到內部是通過AbpApplicationFactory
創建了一個abp應用程式的驅動AbpApplicationWithExternalServiceProvider
,在這個驅動類中完成了對abp框架啟動的配置和操作。
AbpApplicationFactory
: abp應用啟動的基本方式,是整個程式的入口,也是研究模載入機制的入口。根據使用的依賴註入容器的不同,提供兩類的Create方法的重載。
應用程式引擎(容器)初始化時,通過應用程式引擎IAbpAppliaction
,即AbpApplicationWithExternalServiceProvider
,拿到各個模塊信息(通過模塊描述),執行各個模塊中配置好的依賴註入。
而通過InitializeApplication(this IApplicationBuilder app)
方法,可以看到也是通過容器拿到驅動,即AbpApplicationWithExternalServiceProvider
示例,然後調用了Initialize(IServiceProvider serviceProvider)
方法。
ABP框架應用程式啟動,模塊載入整個過程涉及到了AbpApplicationFactory
、AbpApplicationWithExternalServiceProvider
、AbpApplicationBase
、IModuleLoader
、IModuleManager
等類和介面,這裡不好把這些源碼都列出來,所以就整理了一下簡單的流程和調用關係。見下圖。
abp應用程式初始化過程圖
以上,就是對Abp應用程式啟動和模塊載入機制的整理.
除此之外,volo.abp.core類庫中還提供了一些工具類和擴展方法,都是很好用的,就算不用abp框架的童鞋也可以借鑒其中的寫法,或者直接拿到自己項目中使用。
有興趣的童鞋可以自己再仔細查看一下源碼。
ABP 系列總結:
目錄:ABP 系列總結
上一篇:ABP - 初識 ABP