laravel框架中自帶檔案系統的相關操作的使用是非常方便的,那麼這是如何實現的呢?接下來的這篇文章php中文網將給大家來詳細的說明一下這裡面的原理,話不多說,讓我們直接來看文章的內容。
先來一個引子:
以Laravel 自帶的檔案系統為例,在config/app.php 的設定檔的providers 陣列中,註冊了一個服務提供者:
IlluminateFilesystemFilesystemServiceProvider::class,
在alias 陣列中定義了一個門面:
‘File’ => IlluminateSupportFacadesFile::class,
透過這兩個步驟,我們就可以非常方便的使用Laravel 提供的檔案系統相關的操作,而且呼叫形式很簡潔,如:
File::exist($path),判斷檔案是否存在。
File::get($path, $lock = false),取得一個檔案的內容。
File::append($path, $data),把內容追加到一個檔案最後。
File::files($directory),取得一個目錄下所有檔案。
以下分別來說一說Laravel 的服務提供者和門面模式的內容。
服務提供者
#先看看定義:
服務提供者是所有Laravel應用程式啟動的中心所在。包括你自己的應用程序,以及所有的 Laravel 核心服務,都是透過服務提供者啟動的。
在檔案系統這個服務提供者中,位置/vendor/laravel/framework/src/Illuminate/Filesystem/FilesystemServiceProvider.php,register 方法可以看到綁定了一個單一範例:
protected function registerNativeFilesystem() { $this->app->singleton('files', function () { return new Filesystem; }); }
這個單例是Filesystem 這個類別的單例模式。當然,這個服務提供者中也可以綁定其他的單例,或做更多的事情。我們這裡只研究 File::exist() 這種呼叫方式的原理。
那麼這樣一來就有個 files 的單例,其實就是 Filesystem 這個類別的實例。
此時,如果沒有Facade,也是可以呼叫到Filesystem 這個實例的方法的,那就是這樣呼叫:
app(‘files’)->exist($path)
好了,現在開始講Facade.
Facade 門面模式
Facades 為應用程式的服務容器中可用的類別提供了一個「靜態」介面。 Laravel 自帶了許多的 facades,可以用來訪問其幾乎所有的服務。 Laravel facades 就是服務容器裡那些基類的「靜態代理」,相較於傳統的靜態方法調用,facades 在提供更簡潔且豐富的語法的同時,還有更好的可測試性和擴展性。
本文一開始講到alias 陣列定義了一個File,具體的類別是
IlluminateSupportFacadesFile::class,
它的內容是:
class File extends Facade { /** * Get the registered name of the component. * * @return string */ protected static function getFacadeAccessor() { return 'files'; } }
它實際上回傳了一個名稱,注意這個名稱files,不就是剛剛綁定的單例模式的名稱嗎?沒錯。
這樣一來,就可以使用 File 這個別名或說門面,來呼叫這個 Filesystem 實例中的方法了。
透過本文,希望大家能夠了解服務提供者,Facade,和實際呼叫的類別的實例之間的關係。
以上就是本篇文章的全部內容了,更多laravel內容請關注laravel框架入門教學。
相關文章推薦:
Laravel框架中輔助函數:optional ()函數的介紹
相關課程推薦:
以上是Laravel框架中服務提供者和門面模式(Facade)的用法(代碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!