首頁  >  文章  >  後端開發  >  淺談PHP組件、框架以及Composer

淺談PHP組件、框架以及Composer

little bottle
little bottle轉載
2019-04-23 09:18:383665瀏覽

本篇文章主要介紹了PHP元件、框架以及Composer,具有一定的學習價值,有興趣的朋友可以了解一下。

什麼是元件

元件是一組打包的程式碼,是一系列相關的類別、介面和Trait,用來幫助我們解決PHP應用中某個特定問題。例如,你的PHP應用程式需要收發HTTP請求,可以使用現成的元件如guzzle/guzzle實作。我們使用元件不是為了重新實現已經實現的功能,而是把更多時間花在實現專案的長遠目標上。

優秀的PHP元件具備以下特性:

  • 作用單一:專注於解決一個問題,而且使用簡單的介面封裝功能
  • 小型:小巧玲瓏,只包含解決某個問題所需的最少程式碼
  • 合作:PHP元件之間可以良好合作,組合在一起實現大型專案
  • 測試良好:本身提供測試,而且有充足的測試覆蓋度
  • 文檔完善:應該提供完善的文檔,能讓開發者輕易安裝、理解和使用

元件vs 框架

#我們選擇框架時,要為這個框架的工具投入很多,框架通常會提供大量工具,但卻沒有提供我們所需的某個工具時,痛苦就轉嫁到我們頭上,我們要尋找並整合自訂的PHP庫。把第三方程式碼整合到框架中是件難事,因為第三方程式碼和框架可能沒有使用相同的介面。

選擇框架時,我們看中的是框架的未來,但誰能保證某個框架總是完成某項工作最好的工具呢?存在多年的大型專案必須有好的表現,而且要隨時做好調整,如果選錯了PHP框架,可能無法做到這一點。較舊的PHP框架可能由於缺乏社群支援而變慢或過時,這些舊框架通常使用過程式碼編寫,而沒有使用新式的物件導向程式碼以及PHP的一些新特性,總之,決定是否使用PHP框架時,要考慮的事情很多。

慶幸的是,Laravel在這些擔憂方面表現良好,因此才能在眾多PHP框架中脫穎而出,從某種意義上來說,Laravel也是個基於組件開發的框架(核心組件是自身的Illuminate庫,功能實作上則大量依賴第三方元件),相較於Symfony而言,上手又比較簡單,所以兼具了擴充性和易用性。但是,Laravel也存在一些不足,例如Laravel自身的元件不能輕易解耦,用於Laravel框架之外(但相信這種狀況會有好轉,例如其資料庫和佇列元件就可以解耦出去)。綜合來看,Laravel仍是一個出色的框架,能幫組我們快速創造強大的應用程式。

那我們應該使用元件還是框架呢?答案是,使用正確的工具做正確的事,如果能透過一些PHP元件快速實現小型項目,那就使用元件,如果有多個團隊成員開發大型項目,而且能從框架提供的約定準則和結構中受益,那就使用框架(如果是在糾結使用什麼框架,那麼選擇Laravel吧,它不會讓你失望),使用框架能夠引導並加速專案的開發。

使用元件

Packagist

我們在Packagist中尋找PHP元件,這個網站用於收集PHP元件,最好的PHP元件在Packagist中都能找到。

淺談PHP組件、框架以及Composer

例如我們想使用一個http元件用來收發HTTP訊息,在搜尋框中搜尋http,得到的第一個結果就是Guzzle,就用它吧。

Composer

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/guzzleleague/csv兩個元件,前者用於處理HTTP訊息,後者用於處理CSV資料。下面我們在專案最頂層執行如下指令:

composer require guzzlehttp/guzzle
composer require league/csv

Composer會將依賴安裝到根目錄的vendor目錄下,安裝完成後,會在根目錄下產生composer .jsoncomposer.lock檔案:

淺談PHP組件、框架以及Composer

#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,一行一個,而且至少有一個是死鏈:

淺談PHP組件、框架以及Composer

#然後開啟終端,執行scan.php#腳本:

php scan.php urls.csv

我們傳入了兩個參數,第一個是腳本檔案scan.php的路徑,另一個是CSV檔案的路徑。輸出如下:

淺談PHP組件、框架以及Composer

相關教學:PHP影片教學

以上是淺談PHP組件、框架以及Composer的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除