本文探討如何構建一個簡單的依賴注入容器(DI 容器)PHP 包。文中所有代碼,包括 PHPDoc 註解和單元測試(100% 代碼覆蓋率),都已上傳至 GitHub 倉庫,並在 Packagist 上列出。
關鍵要點:
- 構建 DI 容器有助於開發者理解依賴注入的基本原理和容器的工作機制。
- DI 容器主要有兩個作用:“依賴注入”和“容器”。它需要能夠使用構造器注入或設置器注入方法來實例化和包含服務。
- Symfony 依賴注入容器可作為創建自定義容器的參考。它將容器配置分為參數和服務,允許安全存儲應用程序密鑰。
- 創建 DI 容器涉及創建項目目錄、創建
composer.json
文件以及實現容器互操作接口。它還涉及創建異常和引用類。 - 容器類需要包含用於檢索服務、檢查服務是否已定義、解析參數和初始化服務的方法。它還應該具有防止循環引用的保護機制。
規劃我們的依賴注入容器
首先,我們將“依賴注入容器”拆分為兩個角色:“依賴注入”和“容器”。
依賴注入最常用的兩種方法是構造器注入和設置器注入,即通過構造器參數或方法調用傳遞類依賴項。如果我們的容器能夠實例化和包含服務,則它需要能夠執行這兩種操作。
要成為一個容器,它必須能夠存儲和檢索服務的實例。與創建服務相比,這是一個相當簡單的任務,但仍然值得考慮。 container-interop
包提供了一組容器可以實現的接口。主要接口是 ContainerInterface
,它定義了兩種方法:一種用於檢索服務,另一種用於測試服務是否已定義。
interface ContainerInterface { public function get($id); public function has($id); }
學習其他依賴注入容器
Symfony 依賴注入容器允許我們通過多種不同方式定義服務。在 YAML 中,容器的配置可能如下所示:
parameters: # ... mailer.transport: sendmail services: mailer: class: Mailer arguments: ["%mailer.transport%"] newsletter_manager: class: NewsletterManager calls: - [setMailer, ["@mailer"]]
Symfony 將容器配置分為參數和服務的配置方式非常有用。這允許將 API 密鑰、加密密鑰和身份驗證令牌等應用程序密鑰存儲在從源代碼存儲庫中排除的參數文件中。
在 PHP 中,Symfony 依賴注入組件的相同配置如下所示:
use Symfony\Component\DependencyInjection\Reference; // ... $container->setParameter('mailer.transport', 'sendmail'); $container ->register('mailer', 'Mailer') ->addArgument('%mailer.transport%'); $container ->register('newsletter_manager', 'NewsletterManager') ->addMethodCall('setMailer', array(new Reference('mailer')));
通過在對 setMailer
的方法調用中使用 Reference
對象,依賴注入邏輯可以檢測到此值不應直接傳遞,而應替換為它在容器中引用的服務。這允許輕鬆地將 PHP 值和其他服務注入服務而不會造成混淆。
開始
首先,創建一個新的項目目錄並創建一個 composer.json
文件,Composer 可以使用該文件自動加載我們的類。目前,此文件只將 SitePointContainer
命名空間映射到 src
目錄。
interface ContainerInterface { public function get($id); public function has($id); }
接下來,因為我們將使我們的容器實現容器互操作接口,我們需要使 Composer 下載它們並將它們添加到我們的 composer.json
文件中:
parameters: # ... mailer.transport: sendmail services: mailer: class: Mailer arguments: ["%mailer.transport%"] newsletter_manager: class: NewsletterManager calls: - [setMailer, ["@mailer"]]
除了主要的 ContainerInterface
之外,container-interop
包還定義了兩個異常接口。第一個用於創建服務時遇到的常規異常,另一個用於請求的服務找不到時。我們還將向此列表中添加另一個異常,用於請求的參數找不到時。
(以下內容省略了代碼實現部分,因為篇幅過長,且核心邏輯已在上文中描述。 GitHub 倉庫中的完整代碼包含了異常類、引用類和容器類的完整實現。)
總結
我們學習瞭如何創建一個簡單的依賴注入容器,但是還有很多其他容器具有我們尚未實現的強大功能!
一些依賴注入容器,例如 PHP-DI 和 Aura.Di,提供了一個稱為自動裝配的功能。在這裡,容器會猜測容器中的哪些服務應該注入到其他服務中。為此,它們使用反射 API 來查找有關構造器參數的信息。
您可以隨意派生該倉庫並添加自動裝配等功能,這是一個很好的練習!此外,我們保留了一個公共列表,其中列出了此容器的所有已知派生版本,以便其他人可以看到您所做的工作。只需使用下面的評論與我們分享您的工作,我們將確保將其添加進去。
您也可以使用下面的評論與我們聯繫。讓我們知道您想澄清或解釋的內容,或者您發現的任何錯誤。
(以下內容省略了 FAQs 部分,因為其內容與上文高度重複,且篇幅過長。)
以上是如何構建自己的依賴注入容器的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Laravel使用其直觀的閃存方法簡化了處理臨時會話數據。這非常適合在您的應用程序中顯示簡短的消息,警報或通知。 默認情況下,數據僅針對後續請求: $請求 -

PHP客戶端URL(curl)擴展是開發人員的強大工具,可以與遠程服務器和REST API無縫交互。通過利用Libcurl(備受尊敬的多協議文件傳輸庫),PHP curl促進了有效的執行

Laravel 提供简洁的 HTTP 响应模拟语法,简化了 HTTP 交互测试。这种方法显著减少了代码冗余,同时使您的测试模拟更直观。 基本实现提供了多种响应类型快捷方式: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

您是否想為客戶最緊迫的問題提供實時的即時解決方案? 實時聊天使您可以與客戶進行實時對話,並立即解決他們的問題。它允許您為您的自定義提供更快的服務

文章討論了PHP 5.3中介紹的PHP中的晚期靜態結合(LSB),允許靜態方法的運行時間分辨率調用以更靈活的繼承。 LSB的實用應用和潛在的觸摸

PHP日誌記錄對於監視和調試Web應用程序以及捕獲關鍵事件,錯誤和運行時行為至關重要。它為系統性能提供了寶貴的見解,有助於識別問題並支持更快的故障排除

Laravel的服務容器和服務提供商是其架構的基礎。 本文探討了服務容器,詳細信息服務提供商創建,註冊,並通過示例演示了實際用法。 我們將從OVE開始


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Atom編輯器mac版下載
最受歡迎的的開源編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器