国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

PHP回顧之創建自己的Composer包

KoreyLee / 1680人閱讀

摘要:想要更好的利用協同工作,學會創建自己的包是一項必不可少的技能。編輯項目的或,增加一項配置,例如以上配置使用中國全量鏡像網站作為默認中央倉庫。創建自己的包創建一個包只需兩步填寫包描述信息寫代碼。通過簡單兩步,我們創建的自己的包。

轉載請注明文章出處:https://tlanyan.me/php-review...
PHP回顧系列目錄

PHP基礎

web請求

cookie

web響應

session

數據庫操作

加解密

Composer

前文 PHP回顧之Composer 簡要介紹了Composer的相關概念和簡要用法,應付日常開發已無大礙。想要更好的利用Composer協同工作,學會創建自己的Composer包是一項必不可少的技能。本文先講解Composer倉庫的概念,再給出創建和發布Composer包的步驟。

倉庫(Repository)

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

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

可以配置多個倉庫,Composer會自動找出最適合項目的依賴包。搜索包的流程如下:首先檢查當前項目是否配置額外倉庫,有則優先在額外倉庫中檢索;無結果向上到全局配置中的額外倉庫檢索;未配置或搜索無結果的情況下,回退到默認的Packagist中央倉庫檢索。除非禁用了默認的倉庫,Packagist中的包總會被檢索到。因為這個原因,Composer推薦PHP開發人員將包托管在Packagist網站上,方便他人檢索和引用。

配置倉庫

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

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

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

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

以上配置使用 Packagist中國全量鏡像 網站作為默認中央倉庫。在大陸地區部署PHP項目,建議使用該倉庫目錄,能加速依賴包的下載。

倉庫配置最重要的兩個參數是typeurltype指明倉庫的類型,url則指向具體網址。根據倉庫的位置,常用的type可選值有:

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

vcs,版本控制管理系統,例如Github上的項目地址;

pear,PEAR上的包;

package,位于互聯網上包;

artifact,代碼zip包合集;

path,指向代碼具體位置。

互聯網上的倉庫,type的常見值是composervcs;本地的項目,常見值是artifactpath。具體用例,可參考Composer官方文檔。

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

創建自己的Composer包

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

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

{
    "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/"
        }
    }
}

以上內容基本上是一個Composer包的必備字段。其他字段可參考Composer官網的composer.json說明。需注意標記為root-only的字段,root-only表示當前包為主項目時才生效。例如require-dev字段,在當前項目中開發,字段內的包會下載放到vendor文件夾內;如果該項目被其他項目引用,則該字段的值被忽略,引用的包不會被下載。

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

namespace tlanyan;

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

代碼風格建議參考PSR-2規范,文件命名和路徑規范建議參考PSR-4規范。另外需注意文件的路徑需與composer.jsonautoload的值相匹配。

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

引用Composer包

新建一個test項目,引用上文創建的包并查看效果,步驟如下:

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

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

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

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

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

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

4.執行Test.php:php Test.php,輸出"Hello, Composer!"。

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

發布Composer包

將Composer包發布到互聯網的方式有幾種:

打包成zip,上傳到任意一個可公開訪問的網站;

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

提交到PEAR社區;

提交到私有的Composer倉庫;

提交到Packagist。

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

提交包到Packagist,要經歷以下過程:

在Github創建項目并提交代碼;

在Packagist輸入項目地址提交包;

在Github配置項目,觸發Packagist自動更新。

前兩步是必須的,第三步可選。本著為提交的包負責的態度,強烈建議完成第三步操作。

提交包的過程涉及到Github和Packagist兩個站點,Github和Packagist之間的關系為:Github托管實際的代碼和文件;Packagist托管包的作者、包名、版本號、下載量等元數據保。簡要說Packagist是索引,Github是內容提供方。

詳細步驟可參考官網指引或網上教程,網上相關內容太多,本文不再重復。

總結

本文介紹了Composer倉庫的概念,創建了一個完整的Composer包,并給出提交包到Packagist的指引。用戶掌握相關概念和運行機制后,可提交代碼為社區做貢獻,也可跳出Packagist自由的引用和安裝依賴包。

參考

https://getcomposer.org/doc/

https://packagist.org/about

https://www.phpcomposer.com/

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/28564.html

相關文章

  • PHP回顧Composer

    摘要:本文簡要回顧相關概念和用法。相比之下已是明日黃花。分別對應的命令是根據關鍵字查找依賴包,例如查找本人發布的包。作為目前包依賴管理的最佳工具,值得每一位開發人員掌握。 轉載請注明文章出處:https://tlanyan.me/php-review... PHP回顧系列目錄 PHP基礎 web請求 cookie web響應 session 數據庫操作 加解密 Composer是PHP...

    Ocean 評論0 收藏0
  • PHP回顧執行流程及相關概念

    摘要:通過,腳本層無需過多考慮執行的具體環境,而本身則可以讓針對自己的特點給出特有實現。模式下,也只執行一次。這幾個概念的關系如下網關協議,與語言無關,所以與關系也不大。總結本文簡要回顧了程序的架構和執行流程,并對幾個容易混淆概念做了介紹。 轉載請注明文章出處:https://tlanyan.me/php-review... PHP回顧系列目錄 PHP基礎 web請求 cookie we...

    jsdt 評論0 收藏0
  • PHP回顧socket編程

    摘要:如果你想體驗原味編程,用開頭的比較適合否則建議使用流函數。有關流的知識,請參考本人之前的博文回顧之流。接下來我們用流函數實現一個簡單的客戶端和服務端。流函數中的和兩個函數是我們想要的。本文目的是簡要介紹中的編程,行文到此已經達到目的。 轉載請注明文章出處: https://tlanyan.me/php-review... PHP回顧系列目錄 PHP基礎 web請求 cookie w...

    tomorrowwu 評論0 收藏0
  • PHP回顧發送郵件

    摘要:隨著云服務器的盛行,幾乎無法以指向本機的域名向外發送郵件,除了在本機內發送提醒郵件,用處已然不大。發送效率低非面向對象的調用方式,配置麻煩以及云服務器廠商的封鎖,是使用函數的最大阻礙。 轉載請注明文章出處: https://tlanyan.me/php-review... PHP回顧系列目錄 PHP基礎 web請求 cookie web響應 session 數據庫操作 加解密 Co...

    smallStone 評論0 收藏0
  • PHP回顧IO

    摘要:命令行時返回值為,標準輸入輸出均指向終端可用進程號查看。會在腳本執行完畢后關閉三個流,無需用戶手動關閉。與遠程網址交互是一個請求和響應的過程,其中細節可參考本人之前的文章回顧之請求和回顧之響應,也可參考協議的權威文檔。 轉載請注明文章出處: https://tlanyan.me/php-review... PHP回顧系列目錄 PHP基礎 web請求 cookie web響應 ses...

    happen 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<