溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

PHP怎么創(chuàng)建自己的Composer包方法

發(fā)布時(shí)間:2021-06-07 11:17:52 來源:億速云 閱讀:225 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)PHP怎么創(chuàng)建自己的Composer包方法的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

倉庫(Repository)

倉庫是軟件開發(fā)中常見的概念,與源(sources)意義相近,主要指托管資源的場所。許多軟件都有倉庫的概念,例如yum、npm、maven、Git,以及本文的主角Composer。倉庫以中心化的方式托管資源,為軟件的正常工作提供保障。

Packagist 是Composer默認(rèn)的中央倉庫,PHP社區(qū)的絕大部分Composer包都托管在該網(wǎng)站上。Packagist提供公開的、免費(fèi)的托管服務(wù),任何人均可注冊(cè)、自由發(fā)布包,無需審核。Packagist由Private Packagist提供托管和維護(hù),兩者的主要區(qū)別為:Packagist的官網(wǎng)是https://packagist.org,托管...,托管的代碼無需開源,倉庫服務(wù)器可位于內(nèi)網(wǎng),提供更快、更高效的包代碼托管服務(wù)。

可以配置多個(gè)倉庫,Composer會(huì)自動(dòng)找出最適合項(xiàng)目的依賴包。搜索包的流程如下:首先檢查當(dāng)前項(xiàng)目是否配置額外倉庫,有則優(yōu)先在額外倉庫中檢索;無結(jié)果向上到全局配置中的額外倉庫檢索;未配置或搜索無結(jié)果的情況下,回退到默認(rèn)的Packagist中央倉庫檢索。除非禁用了默認(rèn)的倉庫,Packagist中的包總會(huì)被檢索到。因?yàn)檫@個(gè)原因,Composer推薦PHP開發(fā)人員將包托管在Packagist網(wǎng)站上,方便他人檢索和引用。

配置倉庫

有兩種方法對(duì)Composer的倉庫進(jìn)行配置:命令行和編輯配置文件。composer config是Composer配置的命令,可以用來配置項(xiàng)目或全局的倉庫信息,例如:

composer config [-g] repo.packagist composer https://packagist.phpcomposer.com

第二種方法是編輯配置文件。編輯項(xiàng)目的composer.json或~/.config/composer/config.json,增加repositories一項(xiàng)配置,例如:

"repositories": {
  "packagist": {
    "type": "composer",
    "url": "https://packagist.phpcomposer.com"
  }
}

以上配置使用 Packagist中國全量鏡像 網(wǎng)站作為默認(rèn)中央倉庫。在大陸地區(qū)部署PHP項(xiàng)目,建議使用該倉庫目錄,能加速依賴包的下載。

倉庫配置最重要的兩個(gè)參數(shù)是type和url。type指明倉庫的類型,url則指向具體網(wǎng)址。根據(jù)倉庫的位置,常用的type可選值有:

  1. composer,Composer包托管倉庫,例如 Packagist中國全量鏡像;

  2. vcs,版本控制管理系統(tǒng),例如Github上的項(xiàng)目地址;

  3. pear,PEAR上的包;

  4. package,位于互聯(lián)網(wǎng)上包;

  5. artifact,代碼zip包合集;

  6. path,指向代碼具體位置。

互聯(lián)網(wǎng)上的倉庫,type的常見值是composer和vcs;本地的項(xiàng)目,常見值是artifact和path。具體用例,可參考Composer官方文檔。

掌握了倉庫的概念和其配置,接下來我們創(chuàng)建自己的包。

創(chuàng)建自己的Composer包

創(chuàng)建一個(gè)Composer包只需兩步:1. 填寫包描述信息;2. 寫代碼。本文創(chuàng)建一個(gè)hello-composer的包來演示創(chuàng)建過程。該包功能只有一個(gè):輸出字符串“Hello, Composer!”。

Composer包的描述信息存放在composer.json文件中,可直接新建(或從其他項(xiàng)目拷貝)composer.json文件,手動(dòng)填充必要的字段信息;也可以用composer init命令,交互式的輸入包信息,生成composer.json文件后再補(bǔ)全其他字段信息。我們采取直接編輯文件的方式,在composer.json中輸入如下內(nèi)容:

{
  "name": "tlanyan/hello-composer",
  "description": "Hello, Composer!",
  "type": "library",
  "require": {
    "php": ">=7.0"
  },
  "license": "MIT",
  "authors": [
    {
      "name": "tlanyan",
      "email": "tlanyan@hotmail.com"
    }
  ],
  "minimum-stability": "stable",
  "autoload": {
    "psr-4": {
      "tlanyan\\": "src/"
    }
  }
}

以上內(nèi)容基本上是一個(gè)Composer包的必備字段。其他字段可參考Composer官網(wǎng)的composer.json說明。需注意標(biāo)記為root-only的字段,root-only表示當(dāng)前包為主項(xiàng)目時(shí)才生效。例如require-dev字段,在當(dāng)前項(xiàng)目中開發(fā),字段內(nèi)的包會(huì)下載放到vendor文件夾內(nèi);如果該項(xiàng)目被其他項(xiàng)目引用,則該字段的值被忽略,引用的包不會(huì)被下載。

接下來編寫代碼。在src目錄下新建HelloComposer.php:

namespace tlanyan;

class HelloComposer
{
  public static function greet()
  {
    echo "Hello, Composer!", PHP_EOL;
  }
}

代碼風(fēng)格建議參考PSR-2規(guī)范,文件命名和路徑規(guī)范建議參考PSR-4規(guī)范。另外需注意文件的路徑需與composer.json中autoload的值相匹配。

通過簡單兩步,我們創(chuàng)建的自己的Composer包。接下來在其他項(xiàng)目中引用該包。

引用Composer包

新建一個(gè)test項(xiàng)目,引用上文創(chuàng)建的包并查看效果,步驟如下:

1.新建test文件夾,拷貝或者新建composer.json文件,配置如下:

  {
    ....
    "require": {
      "tlanyan/hello-composer": "*"
    },
    "minimum-stability": "dev",
    "repositories": {
      "local": {
        "type": "path",
        "url": "/path/to/hello-composer"
      }
    },
    ....
  }

配置文件需要注意兩點(diǎn): 1. 如果hello-composer的composer.json文件沒有version字段(或不是穩(wěn)定版),minimum-stability值要是dev(默認(rèn)是stable),否則無法安裝; 2. 需添加自定義倉庫,type值為path。

2.執(zhí)行composer install -vvv安裝依賴包,安裝完成后vendor目錄下生成tlanyan/hello-composer目錄。

3.在test中新建Test.php文件,引用HelloComposer類:

  namespace test;
  
  require "vendor/autoload.php";
  
  use tlanyan\HelloComposer;
  
  class Test
  {
    public static main()
    {
      HelloComposer::greet();
    }
  }
  
  Test::main();

.執(zhí)行Test.php:php Test.php,輸出"Hello, Composer!"。

通過配置Composer倉庫,我們成功引用了創(chuàng)建的hello-composer包。測試沒問題后,就可以發(fā)布到網(wǎng)上供其他人使用。下面簡要說是發(fā)布流程。

發(fā)布Composer包

將Composer包發(fā)布到互聯(lián)網(wǎng)的方式有幾種:

  1. 打包成zip,上傳到任意一個(gè)可公開訪問的網(wǎng)站;

  2. 通過版本控制軟件,上傳到代碼倉庫;

  3. 提交到PEAR社區(qū);

  4. 提交到私有的Composer倉庫;

  5. 提交到Packagist。

前四種方式,需要用戶配置倉庫信息才能檢索到包(PEAR社區(qū)幾乎已死,可以忽略)。如果代碼開源,建議提交到Packagist,方便全世界的PHP開發(fā)者檢索和使用,為Composer生態(tài)做貢獻(xiàn)。

提交包到Packagist,要經(jīng)歷以下過程:

  1. 在Github創(chuàng)建項(xiàng)目并提交代碼;

  2. 在Packagist輸入項(xiàng)目地址提交包;

  3. 在Github配置項(xiàng)目,觸發(fā)Packagist自動(dòng)更新。

前兩步是必須的,第三步可選。本著為提交的包負(fù)責(zé)的態(tài)度,強(qiáng)烈建議完成第三步操作。

提交包的過程涉及到Github和Packagist兩個(gè)站點(diǎn),Github和Packagist之間的關(guān)系為:Github托管實(shí)際的代碼和文件;Packagist托管包的作者、包名、版本號(hào)、下載量等元數(shù)據(jù)保。簡要說Packagist是索引,Github是內(nèi)容提供方。

感謝各位的閱讀!關(guān)于“PHP怎么創(chuàng)建自己的Composer包方法”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI