一般來說,ASP.NET Web應用程序的第一個執行的方法是Global.asax下定義的Start方法。執行這個方法前HttpApplication 實例必須存在,也就是說其構造函數的執行必然是完成了。 ABP開始的地方就是HttpApplication的構造函數。 如下圖一,Abp定義了一個繼承自HttpApplication的類AbpApplication。該類的構造函數里會創建AbpBootstrapper實例,然后再Application_Start方法中調用AbpBootstrapper的Initialize方法(稍后解釋)。 在Abp的實際web項目中Global.asax中定義的HttpApplication派生類必須繼承自AbpWebApplication(如下圖二)。
(圖 一)
(圖 二)
再看AbpBootstrapper的Initialize方法。AbpBootstrapper的Initialize()方法首先給IocManager的IocContainer(也就是IWindsorContainer, ABP使用Castle完成依賴注入) Install AbpCoreInstaller (如圖三). AbpCoreInstaller來注冊系統框架級的所有配置類,具體代碼如下(如圖四)。
(圖 三)
除了DefaultModuleFinder其他都是單例的。AbpCoreInstaller注冊的是系統框架級(核心框架,也就是指Abp項目)的所有configuration. 很容易理解ABP先完成configuration的依賴注入,因為一個功能所依賴的configuration對象一般都是要在功能被使用前完成初始化。
(圖 四)
以下是AbpCoreInstaller代碼在ABP源碼中的位置。
(圖 五)
IocManager的IocContainer就是IWindsorContainer, ABP使用Castle完成依賴注入。
AbpBootstrapper類持有IocManager實例
AbpCoreInstaller只是完成注冊系統框架級的所有配置類。Abp支持自動完成符合Conventional(基於約定)的組件的注冊。 Conventional 的規則要通過繼承IConventionalDependencyRegistrar接口實現。
如下圖,ABP中繼承自IConventionalDependencyRegistrar接口的四個類。 其中BasicConventionalRegistrar設置了所有繼承至ITransientDependency,ISingletonDependency和IInterceptor接口的類都會被自動注冊。
其他三個則分別注冊AbpDbContext,ApiController和Controller的派生類。
BasicConventionalRegistrar的代碼,其注冊所有繼承至ITransientDependency,ISingletonDependency和IInterceptor接口的類。
IIocManager是處理依賴注入的核心接口,他將具體的注冊還有解析功能分別包含在其父接口IIocRegistrar和IIocResolver中。