PHP

开发自己的composer包

逼格提升之利器,了解composer如何工作

Posted by DullCat on February 6, 2018

本猫最近准备开源一个php参数验证的包validate,结果一不小心踩入坑中, 特写此博客,以告后者.

  • 创建一个仓库

    create_repo

  • 有一个能分享的代码,并且规范他

    你可以按照自己的命名,但是为了便于讲解,我先贴出较为常见的结构:

    -src/(主要的代码)
    --src/Validate.php
    --src/Rule.php
    --src/....
    -README.md (使用说明)
    -.gitignore (git上传忽略文件列表,注意加上(.idea/*)编辑器生成目录)
    -composer.json(包的说明)
    
  • 在本地测试代码是否按照预期执行

    如果你想要自己的代码能够被他人正常使用,这一步将非常关键.

1.将包放进vendor目录里

2.在项目根目录的composer.json中写入

    "autoload": {
        "psr-4": {
            "Validate\\": "vendor/Validate/src"
             //("命名空间\\":"路径")
        }
    }

坑:本地测试要加vendor,大小写一定要注意

3.执行composer update

然后在本地测试能否正常加载类,如果能正常加载说明你的包可以被使用了

  • composer.json

    以我的composer.json举例,包里的composer.json非常重要,他不仅是对包的一个描述, 也是composer收录的一个根据

你可以自己直接创建并写入也可以使用命令来创建和写入composer init,这里推荐自己写入,因为自由度更高

{
    "name": "dullcat-c/validate",
     //"供应商/项目名",如果是个人,可以填自己github的名字,记得要全部小写
    "description": "this is a simple library for php data validate", //简介
    "keywords":["validate","filter","php"], //关键词,记得要用数组形式
    "require": { //需要的依赖
        "php": ">=5.3.0"
    },
    "license": "MIT", //证书
    "authors": [ //作者
        {
            "name": "DullCat-c",
            "email": "[email protected]"
        }
    ],
    "autoload": { //加载的协议,注意这里与本地加载时不一样
        "psr-4": {
            "Validate\\": "src/"
        }
    }
}

写完之后记得执行composer validate composer.json来检查一下

  • 提交给packagist

    1.你要拥有一个packagist的账号

2.复制你的存储库URL

vcs_repo

3.submit你的代码 submit

  • 设置自动更新

    1.去到你github项目的主页 2.点击”Settings” 3.点击”Integrations & services” 4.点击”add service”,并添加”Packagist” 5.填写 hook

token

6.检查Packagist是否正常显示,如过没有,说明设置失败,请检查上述步骤 ok

  • 测试是否能使用composer安装

    install

安装的目录为

-composer.json里填写的供应商名
--项目名
---项目文件
---项目文件

坑:版本非常低的php可能在安装的时候需要在composer命令后加上分支名 ex:composer require dullcat-c/validate dev-master


DullCat(一个PHPer)的博客

只要我奔跑的速度够快,就无所谓失去


本文总阅读量