Composer幫你輕松管理PHP包 autoload


在PHP包管理上面,PHP發展的很緩慢,導致的結果就是很少發現程序員會使用像PEAR這樣的工具。相反,大多數開發人員會選擇他們自己喜歡的框架來處理代碼,比如DB交互、ORIM’S、Oauth、Amazon S3整合等。

缺點就是在轉換框架的時候(或者根本不需要返回使用框架)就感覺像在做噩夢,因為涉及到使用新工具,你必須重新學習里面的一切東西,而這並不簡單。OK,Composer來幫助你解決這些問題。

介紹

Composer通過把自己定位成“所有項目的粘合計”來着手解決問題。這也就意味着包可以被寫,開發和以某種格式進行共享,其他開發人員可以輕松插入到應用程序中。

這篇文章將向大家講解如何安裝和使用Composer包。在文章最后,你就可以把代碼塊插入到任何一個框架中進行體驗,你可以使用CodeIgniterFuelPHPLaravelSymfony2,LithiumYiiZend等。

安裝

Composer包含兩大邏輯部分:一個是用來存儲包,另一個是命令行應用程序,幫助你發現、下載、更新和分享代碼。

  1. $ cd/path/to/my/project  
  2. $ curl -s http://getcomposer.org/installer| php 

在項目列表中,會有一個composer.phar文件,里面包含了所有邏輯代碼行工具。你可以通過運行下面代碼來確定是否安裝成功。

  1. $ php composer.phar 

這個命令執行后會顯示所有可用的命令。

我個人比較建議大家使用這個命令:

  1. $ sudo mv composer.phar /usr/bin/composer 

把這個文件移到bin目錄下,它允許你簡化命令。

  1. $ composer about 

如果你是在Windows上運行,你可以下載這個文件,然后通過PHP解析器安裝,無論在哪里都可以。

解析composer.json文件

如果你是一名Ruby程序員,你會覺得這個文件跟Gemfile文件很相似,或者你是一個Node程序員,那么會覺得和package.json文件很像。同樣,Composer會根據你的應用需求用composer.json文件來指定設置和封裝。

在大多數基本的form里面,composer文件看起來是這樣的:

  1. {  
  2.     "require": {  
  3.         "kriswallsmith/assetic": "*"  
  4.     }  

意思是需要一個“assetic”包,通過“kriswallsmith”創建和指定任意一個版本。你也可以指定一個特殊的版本,你可以使用下面命令代替:

  1. "kriswallsmith/assetic": "1.0.3" 

你甚至還可以使用這種方法:

  1. "kriswallsmith/assetic": "1.0.*" 

這個有一些微小的變化,但是他不會升級到1.1.0,程序員需要注意界面上細微的變化。

安裝要求

現在,在你的composer.json文件下面會有一個或多個包,這個時候可以運行:

  1. $ php composer.phar install 

或者,如果你聽了我的建議,你只需要在Unix機器上面運行:

  1. $ composer install 

你會發現,正在下載文件並且會放在應用程序根目錄下面的vendors文件夾里面。這個邏輯也可以使用下面的配置:

  1. {  
  2.     "require": {  
  3.         "kriswallsmith/assetic": "1.0.*"  
  4.     },  
  5.     "config" : {  
  6.         "vendor-dir" : "packages"  
  7.     }  

自動加載

自動加載在PHP里面有一點亂糟糟的,作為開發人員,他們有屬於自己操作方式。比如Smarty包,使用自己的自動載入。有一些開發人員會把多個類放到一個文件里面,或者文件名小寫,這些做法都太隨意啦!

PHP官方社區創建了PSR-0標准,從而來規范這些隨意的做法。Composer默認支持這個標准。Composer里面自帶PSR-0自動加載機制,在項目里面加入下面一行代碼:

  1. include_once './vendor/autoload.php'; 

顯然,如果autoload.php文件目錄有變化,你也需要在代碼里面做出相應改動。

下面,你可以在應用程序中使用如下代碼:

  1. <?php   
  2. use Assetic\Asset\AssetCollection;  
  3. use Assetic\Asset\FileAsset;  
  4. use Assetic\Asset\GlobAsset;  
  5. $js = new AssetCollection(array(  
  6.     new GlobAsset('/path/to/js/*'),  
  7.     new FileAsset('/path/to/another.js'),  
  8. ));  
  9.    
  10. // the code is merged when the asset is dumped  
  11. echo $js->dump();  

這是一個使用Assetic的例子,當然,這里也有許多命名空間代碼,但是這樣做是為了避免包之間互相沖突。

PSR-0的命名慣例本質是:

  1. \<Vendor Name>\(<Namespace>\)*<Class Name> 

下面這個例子是Buzz HTTP包:

  1. $browser = new Buzz\Browser;  
  2. $response = $browser->get('http://www.google.com');  
  3. echo $browser->getLastRequest()."\n";  
  4. echo $response;  

看起來像是被美化的file_get_contents(),但是它處理所有類型的智能邏輯,並且在后台處理HTTP Response/Request,你也會發現命名空間語法也不是那么的強烈。

真實的世界

目前,大多數PHP存儲依靠主代碼庫。如果你使用Facebook SDK,例如,你僅僅從GitHub或者zip文件中通過復制粘貼的方式把版本推到你的代碼中,然后把它放到你的版本控制系統里面,將會變更。

版本和你的代碼只是作為靜態文件放在里面,在某種意義上,你可能會忘記升級,如果你關注到Facebook已經發布了一個新版本。最新版本文件會顯示在最上面。

使用Composer就無需關注版本變化情況,你只需運行一下更新,那么所有需要更新的都會自動更新。但是為什么還會有大量的代碼在你的倉庫里呢?你不需要它們在那里嗎?

最干脆的做法是添加vendors到你的“Ignore”列表里面(例如gitignore)並且讓你的代碼完全離開那里。當你在部署代碼的時候,你只需運行composer install或者composer update。

如果你想使用更熟練,你可以手動運行整個過程,如果你有雲端托管你可以設置hooks,一旦代碼發布,就運行。

總結

將來,你將會看到更多的Composer,各種豐富多彩的框架已經開始提供了多種層次的集成。FuelPHP將構建Composer包,CodeIgniter提供自動加載並且已經在Symfony2上廣泛使用。

使用Composer添加相關包到你的項目里面是一個很好的方式,無需安裝PECLI擴展或者復制粘貼一個系列文件。那種方式已經很過時了,並且還浪費你大量的時間。(編譯:張紅月)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM