laravel依賴注入一詞是由Martin Fowler提出的術語,它是將元件注入到應用程式中的一種行為,依賴注入是敏捷架構中關鍵元素,使用範例如「class UserProvider{protected $connection...}」。
本文操作環境中:windows7系統、Laravel5.7版,DELL G3電腦。
laravel 依賴注入是什麼?
詳解Laravel 中的依賴注入和IoC:
作為開發者,我們一直在嘗試透過使用設計模式和嘗試新的健壯型框架來尋找新的方式來編寫設計良好且健壯的程式碼。在本篇文章中,我們將透過 Laravel 的 IoC 元件探索依賴注入設計模式,並了解它如何改進我們的設計。
依賴注入
依賴注入一詞是由 Martin Fowler 提出的術語,它是將元件注入到應用程式中的一種行為。就像 Ward Cunningham 說的:
依賴注入是敏捷架構中關鍵元素。
讓我們來看一個例子:
class UserProvider{ protected $connection; public function __construct(){ $this->connection = new Connection; } public function retrieveByCredentials( array $credentials ){ $user = $this->connection ->where( 'email', $credentials['email']) ->where( 'password', $credentials['password']) ->first(); return $user; } }
如果你要測試或維護這個類,你必須存取資料庫的實例來進行一些查詢。為了避免必須這樣做,你可以將此類與其他類別進行 解耦 ,你有三個選項之一,可以將 Connection
類別注入而不需要直接使用它。
將元件注入類別時,可以使用以下三個選項之一:
建構方法注入
class UserProvider{ protected $connection; public function __construct( Connection $con ){ $this->connection = $con; } ...
Setter 方法注入
同樣,我們也可以使用Setter 方法注入依賴關係:
class UserProvider{ protected $connection; public function __construct(){ ... } public function setConnection( Connection $con ){ $this->connection = $con; } ...
介面注入
interface ConnectionInjector{ public function injectConnection( Connection $con ); } class UserProvider implements ConnectionInjector{ protected $connection; public function __construct(){ ... } public function injectConnection( Connection $con ){ $this->connection = $con; } }
當一個類別實作了我們的介面時,我們定義了injectConnection
方法來解決依賴關係。
優勢
現在,當測試我們的類別時,我們可以模擬依賴類別並將其作為參數傳遞。每個類別必須專注於一個特定的任務,而不應該關心解決它們的依賴性。這樣,你將擁有一個更專注和可維護的應用程式。
如果你想了解更多關於 DI 的信息,Alejandro Gervassio 在 本系列 文章中對其進行了廣泛而專業的介紹,所以一定要去讀這些文章。那麼,什麼又是 IoC 呢? IoC (控制反轉)不需要使用依賴注入,但它可以幫助你有效的管理依賴關係。
控制反轉
Ioc 是一個簡單的元件,可以更方便地解析依賴項。你可以將物件形容為容器,每次解析類別時,都會自動注入依賴項。
Laravel Ioc
當你請求一個物件時, Laravel Ioc 在解決依賴關係的方式上有些特殊:
我們使用一個簡單的例子,將在本文中改進它。 SimpleAuth
類別依賴FileSessionStorage
,所以我們的程式碼可能是這樣的:
class FileSessionStorage{ public function __construct(){ session_start(); } public function get( $key ){ return $_SESSION[$key]; } public function set( $key, $value ){ $_SESSION[$key] = $value; } } class SimpleAuth{ protected $session; public function __construct(){ $this->session = new FileSessionStorage; } } //创建一个 SimpleAuth $auth = new SimpleAuth();
這是一個經典的方法,讓我們從使用建構函數注入開始。
class SimpleAuth{ protected $session; public function __construct( FileSessionStorage $session ){ $this->session = $session; } }
現在我們建立一個物件:
$auth = new SimpleAuth( new FileSessionStorage() );
現在我想使用 Laravel Ioc 來管理這一切。
因為 Application
類別繼承自 Container
類,所以你可以透過 App
門面來存取容器。
App::bind( 'FileSessionStorage', function(){ return new FileSessionStorage; });
bind
方法第一個參數是要綁定到容器的唯一ID ,第二個參數是一個回呼函數每當執行FileSessionStorage
類別時執行,我們也可以傳遞一個表示類別名稱的字串,如下所示。
Note: 如果你查看Laravel 套件時,你會看到綁定有時會分組,例如( view
, view.finder
# ……)。
假設我們將會話存儲轉換為Mysql 存儲,我們的類別應該類似於:
class MysqlSessionStorage{ public function __construct(){ //... } public function get($key){ // do something } public function set( $key, $value ){ // do something } }
現在我們已經更改了依賴項,我們還需要更改SimpleAuth
構造函數,並將新物件綁定到容器中!
高階模組不應該依賴低階模組,兩者都應該依賴抽象物件。
抽像不應該依賴細節,細節應該取決於抽象。Robert C. Martin
我們的 SimpleAuth
類別不應該關心我們的儲存是如何完成的,相反地它更應該關注於消費的服務。
因此,我們可以抽象實現我們的儲存:
interface SessionStorage{ public function get( $key ); public function set( $key, $value ); }
這樣我們就可以實作並請求 SessionStorage
介面的實例:
class FileSessionStorage implements SessionStorage{ public function __construct(){ //... } public function get( $key ){ //... } public function set( $key, $value ){ //... } } class MysqlSessionStorage implements SessionStorage{ public function __construct(){ //... } public function get( $key ){ //... } public function set( $key, $value ){ //... } } class SimpleAuth{ protected $session; public function __construct( SessionStorage $session ){ $this->session = $session; } }
如果我们使用 App::make('SimpleAuth')
通过容器解析 SimpleAuth
类,容器将会抛出 BindingResolutionException
,尝试从绑定解析类之后,返回到反射方法并解析所有依赖项。
Uncaught exception 'Illuminate\Container\BindingResolutionException' with message 'Target [SessionStorage] is not instantiable.'
容器正试图将接口实例化。我们可以为该接口做一个具体的绑定。
App:bind( 'SessionStorage', 'MysqlSessionStorage' );
现在每次我们尝试从容器解析该接口时,我们会得到一个 MysqlSessionStorage
实例。如果我们想要切换我们的存储服务,我们只要变更一下这个绑定。
Note: 如果你想要查看一个类是否已经在容器中被绑定,你可以使用 App::bound('ClassName')
,或者可以使用 App::bindIf('ClassName')
来注册一个还未被注册过的绑定。
Laravel Ioc 也提供 App::singleton('ClassName', 'resolver')
来处理单例的绑定。
你也可以使用 App::instance('ClassName', 'instance')
来创建单例的绑定。
如果容器不能解析依赖项就会抛出 ReflectionException
,但是我们可以使用 App::resolvingAny(Closure)
方法以回调函数的形式来解析任何指定的类型。
Note: 如果你为某个类型已经注册了一个解析方式 resolvingAny
方法仍然会被调用,但它会直接返回 bind
方法的返回值。
小贴士
这些绑定写在哪儿:
如果只是一个小型应用你可以写在一个全局的起始文件global/start.php
中,但如果项目变得越来越庞大就有必要使用 Service Provider 。测试:
当需要快速简易的测试可以考虑使用php artisan tinker
,它十分强大,且能帮你提升你的 Laravel 测试流程。Reflection API:
PHP 的 Reflection API 是非常强大的,如果你想要深入 Laravel Ioc 你需要熟悉 Reflection API ,可以先看下这个 教程 来获得更多的信息。
相关推荐:最新的五个Laravel视频教程
以上是laravel 依賴注入是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

在Laravel中集成Sentry和Bugsnag可以提高應用的穩定性和性能。 1.在composer.json中添加SentrySDK。 2.在config/app.php中添加Sentry服務提供者。 3.在.env文件中配置SentryDSN。 4.在App\Exceptions\Handler.php中添加Sentry錯誤報告。 5.使用Sentry捕獲並報告異常,並添加額外上下文信息。 6.在App\Exceptions\Handler.php中添加Bugsnag錯誤報告。 7.使用Bugsnag監

Laravel依然是PHP开发者的首选框架,因为它在开发体验、社区支持和生态系统上表现卓越。1)其优雅的语法和丰富的功能集,如EloquentORM和Blade模板引擎,提升了开发效率和代码可读性。2)庞大的社区提供了丰富的资源和支持。3)尽管学习曲线较陡且可能导致项目复杂性增加,但通过合理配置和优化,Laravel能显著提升应用性能。

在Laravel中構建實時聊天應用需要使用WebSocket和Pusher。具體步驟包括:1)在.env文件中配置Pusher信息;2)設置broadcasting.php文件中的廣播驅動為Pusher;3)使用LaravelEcho訂閱Pusher頻道並監聽事件;4)通過PusherAPI發送消息;5)實現私有頻道和用戶認證;6)進行性能優化和調試。

在Laravel中,可以使用Redis和Memcached來優化緩存策略。 1)配置Redis或Memcached需要在.env文件中設置連接參數。 2)Redis支持多種數據結構和持久化,適用於復雜場景和數據丟失風險高的場景;Memcached適合簡單數據的快速訪問。 3)使用Cachefacade進行統一的緩存操作,底層會自動選擇配置的緩存後端。

在不同操作系統上搭建Laravel環境的步驟如下:1.Windows:使用XAMPP安裝PHP和Composer,配置環境變量,安裝Laravel。 2.Mac:使用Homebrew安裝PHP和Composer,安裝Laravel。 3.Linux:使用Ubuntu更新系統,安裝PHP和Composer,安裝Laravel。每個系統的具體命令和路徑有所不同,但核心步驟一致,確保順利搭建Laravel開發環境。

Laravel和Yii的主要區別在於設計理念、功能特性和使用場景。 1.Laravel注重開發的簡潔和愉悅,提供豐富的功能如EloquentORM和Artisan工具,適合快速開發和初學者。 2.Yii強調性能和效率,適用於高負載應用,提供高效的ActiveRecord和緩存系統,但學習曲線較陡。

Laravel適合開發電商系統,因為它能快速搭建高效系統並提供藝術般的開發體驗。 1)商品管理通過EloquentORM實現CRUD操作和分類關聯。 2)支付集成通過StripeAPI處理支付請求和異常,確保支付流程的安全性和可靠性。

2024年必備的Laravel擴展包包括:1.LaravelDebugbar,用於監控和調試代碼;2.LaravelTelescope,提供詳細的應用監控;3.LaravelHorizon,管理Redis隊列任務。這些擴展包能提升開發效率和應用性能。


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。