本篇文章主要介紹了PHP元件、框架以及Composer,具有一定的學習價值,有興趣的朋友可以了解一下。
元件是一組打包的程式碼,是一系列相關的類別、介面和Trait,用來幫助我們解決PHP應用中某個特定問題。例如,你的PHP應用程式需要收發HTTP請求,可以使用現成的元件如guzzle/guzzle實作。我們使用元件不是為了重新實現已經實現的功能,而是把更多時間花在實現專案的長遠目標上。
優秀的PHP元件具備以下特性:
#我們選擇框架時,要為這個框架的工具投入很多,框架通常會提供大量工具,但卻沒有提供我們所需的某個工具時,痛苦就轉嫁到我們頭上,我們要尋找並整合自訂的PHP庫。把第三方程式碼整合到框架中是件難事,因為第三方程式碼和框架可能沒有使用相同的介面。
選擇框架時,我們看中的是框架的未來,但誰能保證某個框架總是完成某項工作最好的工具呢?存在多年的大型專案必須有好的表現,而且要隨時做好調整,如果選錯了PHP框架,可能無法做到這一點。較舊的PHP框架可能由於缺乏社群支援而變慢或過時,這些舊框架通常使用過程式碼編寫,而沒有使用新式的物件導向程式碼以及PHP的一些新特性,總之,決定是否使用PHP框架時,要考慮的事情很多。
慶幸的是,Laravel在這些擔憂方面表現良好,因此才能在眾多PHP框架中脫穎而出,從某種意義上來說,Laravel也是個基於組件開發的框架(核心組件是自身的Illuminate庫,功能實作上則大量依賴第三方元件),相較於Symfony而言,上手又比較簡單,所以兼具了擴充性和易用性。但是,Laravel也存在一些不足,例如Laravel自身的元件不能輕易解耦,用於Laravel框架之外(但相信這種狀況會有好轉,例如其資料庫和佇列元件就可以解耦出去)。綜合來看,Laravel仍是一個出色的框架,能幫組我們快速創造強大的應用程式。
那我們應該使用元件還是框架呢?答案是,使用正確的工具做正確的事,如果能透過一些PHP元件快速實現小型項目,那就使用元件,如果有多個團隊成員開發大型項目,而且能從框架提供的約定準則和結構中受益,那就使用框架(如果是在糾結使用什麼框架,那麼選擇Laravel吧,它不會讓你失望),使用框架能夠引導並加速專案的開發。
我們在Packagist中尋找PHP元件,這個網站用於收集PHP元件,最好的PHP元件在Packagist中都能找到。
例如我們想使用一個http元件用來收發HTTP訊息,在搜尋框中搜尋http,得到的第一個結果就是Guzzle,就用它吧。
Packagist是尋找PHP元件的社區,Composer則是安裝PHP元件的工具。 Composer是PHP的依賴管理器,運行在命令列中,你告訴Composer需要哪些元件,Composer會下載並把這些元件自動載入到你的專案中,就這麼簡單。
Composer和Packagist緊密合作,如果你告訴Composer想要使用guzzlehttp/guzzle
元件,Composer會從Packagist中取得guzzlehttp/guzzle
元件,找到這個元件的倉庫位址,確定要使用哪個版本,還能找出這個元件的依賴,然後把guzzlehttp/guzzle
元件及其依賴下載到你的專案中。
此外,Composer會為專案中的所有PHP元件自動產生符合PSR標準的自動載入器,有效地抽象化了依賴管理和自動加載,所以,對PHP社群來說,Composer是最重要的附加工具,沒有之一,想想之前我們要使用諸如include、require、spl_autoload_register來手動實現自動加載的痛苦日子,這一點也不為過。
關於Composer的安裝與使用,這裡不贅述,請參考Composer中文網。
下面我們透過一個範例專案來示範如何使用Composer和元件來開發一個PHP應用,這個應用的作用是掃描一個CSV檔案中的URL,找出死鏈,這個應用會向每個URL發HTTP請求,如果回傳的HTTP狀態碼大於等於400,就把這個死鏈發給標準輸出。這是一個命令列應用,開發好之後,我們會執行這個腳本,傳入csv檔案的路徑,在標準輸出中顯示死鏈清單。
開始之前,先看看哪些任務可以使用現有的PHP元件解決:我們需要一個可以迭代處理csv檔案資料的元件,此外也要向csv檔案中的每個URL發送HTTP請求,因此還需要一個可以發送HTTP請求並檢查HTTP回應的元件。
瀏覽Packagist後,我們找到guzzlehttp/guzzle
和league/csv
兩個元件,前者用於處理HTTP訊息,後者用於處理CSV資料。下面我們在專案最頂層執行如下指令:
composer require guzzlehttp/guzzle composer require league/csv
Composer會將依賴安裝到根目錄的vendor
目錄下,安裝完成後,會在根目錄下產生composer .json
和composer.lock
檔案:
#composer.lock
檔案中會列出專案使用的所有PHP元件,以及元件的具體版本號,這其實是鎖定了項目,讓項目只能使用特定版本的PHP元件。這樣的好處是,composer會下載這個檔案中列出的特定版本,而不管Packagist中可用的最新版本是多少,你應該把composer.lock
檔案納入版本控制,這樣讓團隊成員使用的PHP版本和你一樣,如果本機開發和伺服器使用的PHP元件版本相同,可以盡量降低由元件版本不同導致的bug。
如果確實要下載最新版本的元件並更新composer.lock
,可以使用composer update
指令。
接下來我們來寫應用程式碼,在根目錄下創建一個scan.php
文件,然後在該文件頂部使用require
導入Composer建立的自動載入器:
require 'vendor/autoload.php';
Composer建立的自動載入器其實就是一個名為autoload.php
的文件,儲存在vendor
目錄中,Composer下載各個PHP元件時,會檢查每個元件的composer.json
文件,決定如何載入該元件,得到這個資訊後,Composer會在本地為該元件建立一個符合PSR標準的自動加載器。這樣我們就可以實例化專案中的任何PHP元件,這些元件會按需自動載入。
下面我們正式使用Guzzle和CSV元件來寫scan.php
程式碼:
//使用composer自动加载器 require 'vendor/autoload.php'; //实例Guzzle Http客户端 $client = new GuzzleHttp\Client(); //打开并迭代处理CSV $csv = League\Csv\Reader::createFromPath($argv[1]); foreach ($csv as $csvRow) { try { //发送HTTP GET请求 $httpResponse = $client->get($csvRow[0]); //检查HTTP响应的状态码 if($httpResponse->getStatusCode() >= 400) { throw new Exception(); } } catch (Exception $e) { //把死链发给标准输出 echo $csvRow[0] . PHP_EOL; } }
下面我們在urls.csv
中加入一些URL,一行一個,而且至少有一個是死鏈:
#然後開啟終端,執行scan.php
#腳本:
php scan.php urls.csv
我們傳入了兩個參數,第一個是腳本檔案scan.php
的路徑,另一個是CSV檔案的路徑。輸出如下:
相關教學:PHP影片教學
以上是淺談PHP組件、框架以及Composer的詳細內容。更多資訊請關注PHP中文網其他相關文章!