小編給大家分享一下composer.lock文件的作用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)建站10多年企業(yè)網(wǎng)站設(shè)計服務(wù);為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及高端網(wǎng)站定制服務(wù),企業(yè)網(wǎng)站設(shè)計及推廣,對樓梯護欄等多個方面擁有豐富的網(wǎng)站推廣經(jīng)驗的網(wǎng)站建設(shè)公司。
Composer的基本使用
在項目中使用composer.json
在項目中使用composer,你需要有一個composer.json文件,此文件的作用主要用來聲明包之間的相互關(guān)系和其他的一些元素標簽。
require 關(guān)鍵字
第一件事情在composer.json就是使用require關(guān)鍵字了,你將告訴composer哪些包是你項目所需要的
代碼如下:
{ "require": { "monolog/monolog": "1.0.*" } }
如你所見,require的對象將會映射包的名稱( monolog/monolog)和包的版本是1.0.*
包的命名
基本上包的命名是 主名/項目名稱( monolog/monolog),主名必須唯一,但是項目也就是我們的包的名稱可以有相同的,例如: igorw/json,和seldaek/json
包的版本
我們需要使用monolog的版本是1.0.*,他的意思是只要版本是1.0分支即可,例如1.0.0,1.0.2或者1.0.99
版本定義的兩種方式:
1. 標準的版本:定義保準的版本包文件,如:1.0.2
2. 一定范圍的版本:使用比較符號來定義有效的版本的范圍,有效的符號有>, >=, <,<=, !=
3. 通配符:特別的匹配符號*,例如1.0.*就相當于>=1.0,<1.1版本的即可
4. 下一個重要的版本:~符號最好的解釋就是,~1.2就相當于>1.2,<2.0,但~1.2.3就相當于>=1.2.3,<1.3版本。
安裝包
在項目文件路徑下運行
代碼如下:
$ composer install
這樣子他會自動下載monolog/monolog文件到你的vendor目錄下面。
接下來需要說明一件事情就是
composer.lock - 鎖定文件
在安裝完所有需要的包之后,composer會生成一張標準的包版本的文件在composer.lock文件中。這將鎖定所有包的版本。
使用composer.lock(當然是和composer.json一起)來控制你的項目的版本
這一點非常的重要,我們使用install命令來處理的時候,它首先會判斷composer.lock文件是否存在,如果存在,將會下載相對應(yīng)的版本(不會在于composer.json里面的配置),這意味著任何下載項目的人都將會得到一樣的版本。
如果不存在composer.lock,composer將會通過composer.json來讀取需要的包和相對的版本,然后創(chuàng)建composer.lock文件
這樣子就可以在你的包有新的版本之后,你不會自動更新了,升級到新的版本,使用update命令即可,這樣子就能獲取最新版本的包并且也更新了你的composer.lock文件。
$ php composer.phar update 或者 $ composer update
Packagist(這應(yīng)該就是composer,感覺有點像python的包,雖然沒那么強大,呵呵,有了這種標準以后,以后大家開發(fā)網(wǎng)站絕對會很輕松,可以借鑒很多人的代碼了,并且更加方便了?。?/p>
Packagist是composer的主要倉庫,大家可以去看看,composer倉庫的基礎(chǔ)是包的源碼,你可以隨意的獲取,Packagist的目的建成一個任何人都可以使用的倉庫,這就意味著在你的文件中任意的require包了。
關(guān)于自動加載
為了方便的加載包文件,Composer自動生成了一個文件 vendor/autoload.php,你可以方便只有的使用它在任何你需要使用的地方
require 'vendor/autoload.php';
這意味著你可以非常非常方便的使用第三方代碼了,假設(shè)你的項目需要使用monlog,你直接使用吧,他們都已經(jīng)自動加載了的!
代碼如下:
$log = new Monolog\Logger('name'); $log->pushHandler(new Monolog\Handler\StreamHandler('app.log', Monolog\Logger::WARNING)); $log->addWarning('Foo');
當然你也可以在composer.json中加載自己的代碼:
代碼如下:
{ "autoload": { "psr-0": {"Acme": "src/"} } }
composer將會把psr-0注冊為Acme的命名空間
你可以定義一個映射通過命名空間到文件目錄,src目錄是你的根目錄,vendor是同一級別的目錄,例如一個文件為:src/Acme/Foo.php就包含了Acme\Foo類
當你在增加autoload之后,你必須要重新install來生成vendor/autoload.php文件
在我們引用此文件的時候,將會返回一個autoloader類的實力,所以你可以把返回的值放入一個變量,然后在增加更多的命名空間,如果在開發(fā)環(huán)境下這是非常方便的,例如:
代碼如下:
$loader = require 'vendor/autoload.php'; $loader->add('Acme\Test', __DIR__);
composer.lock文件的作用
install 命令從當前目錄讀取 composer.json 文件,處理了依賴關(guān)系,并把其安裝到 vendor 目錄下。
代碼如下:
composer install
如果當前目錄下存在 composer.lock 文件,它會從此文件讀取依賴版本,而不是根據(jù) composer.json 文件去獲取依賴。這確保了該庫的每個使用者都能得到相同的依賴版本。
如果沒有 composer.lock 文件,composer 將在處理完依賴關(guān)系后創(chuàng)建它。
為了獲取依賴的最新版本,并且升級 composer.lock 文件,你應(yīng)該使用 update 命令。
代碼如下:
composer update
這將解決項目的所有依賴,并將確切的版本號寫入 composer.lock。
如果你只是想更新幾個包,你可以像這樣分別列出它們:
代碼如下:
composer update vendor/package vendor/package2
你還可以使用通配符進行批量更新:
代碼如下:
composer update vendor/*
以上是“composer.lock文件的作用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!