我們一致在說 ASP.NET Core廣泛地使用到了依賴注入,通過前面兩個系列的介紹,相信讀者朋友已經(jīng)體會到了這一點。由于前面兩章已經(jīng)涵蓋了依賴注入在管道構(gòu)建過程中以及管道在處理請求過程的應(yīng)用,但是內(nèi)容相對分散和零碎,我們有必要針對這個主題作一個歸納性的介紹。采用依賴注入的服務(wù)均由某個ServiceProvider來提供,但是在ASP.NET Core管道涉及到兩個不同的ServiceProvider,其中一個是在管道成功構(gòu)建后創(chuàng)建并綁定到WebHost上的ServiceProvider,對應(yīng)著WebHost的Services屬性。另一個ServiceProvider則是在管道處理每個請求時即時創(chuàng)建的,它綁定當(dāng)表示當(dāng)前請求上下文上,對應(yīng)著HttpContext的RequestServices屬性,兩個ServiceProvider之間存在著父子關(guān)系。[本文已經(jīng)同步到《ASP.NET Core框架揭秘》之中]
目錄
一、WebHost的ServiceProvider
二、HttpContext的ServiceProvider
原理分析
實例證明
兩個ServiceProvider具有“父子”關(guān)系
ServiceProvidersFeature特性
RequestServicesContainerMiddleware中間件
AutoRequestServicesStartupFilter
一、WebHost的ServiceProvider
ASP.NET Core的依賴注入框架其實很簡單,其中僅僅涉及ServiceCollection和ServiceProvider這兩個核心對象。我們預(yù)先將服務(wù)描述信息注冊到ServiceCollection之上,然后利用ServiceCollection來創(chuàng)建ServiceProvider,并最終利用后者根據(jù)指定的服務(wù)類型來提供對應(yīng)的服務(wù)實例。接下來我們以這兩個對象作為唯一的關(guān)注點來回顧一下管道的創(chuàng)建流程。ASP.NET Core管道的創(chuàng)建也僅僅涉及到兩個核心對象,作為應(yīng)用宿主的WebHost對象和創(chuàng)建它的WebHostBuilder。下圖基本揭示了WebHostBuilder創(chuàng)建WebHost,以及WebHost在開啟過程針對依賴注入這兩個核心對象的使用。
ASP.NET Core管道在構(gòu)建過程中會使用同一個ServiceCollection,所有注冊的服務(wù)都被添加到這個對象上。這個ServiceCollection對象最初由WebHostBuilder創(chuàng)建。在WebHost的創(chuàng)建過程中,WebHostBuilder需要向這個ServiceCollection對象注冊兩種類型的服務(wù):一種是確保管道能夠被成功構(gòu)建并順利處理請求所必需的服務(wù),我們不妨將它們稱為系統(tǒng)服務(wù);另一種則是用戶通過調(diào)用ConfigureServices方法自行注冊的服務(wù),我們姑且稱它們?yōu)?span>用戶服務(wù)。