PHP创建自己的Composer包方法
仓库(Repository)
仓库是软件开发中常见的概念,与源(sources)意义相近,主要指托管资源的场所。许多软件都有仓库的概念,例如yum、npm、maven、Git,以及本文的主角Composer。仓库以中心化的方式托管资源,为软件的正常工作提供保障。
Packagist 是Composer默认的中央仓库,PHP社区的绝大部分Composer包都托管在该网站上。Packagist提供公开的、免费的托管服务,任何人均可注册、自由发布包,无需审核。Packagist由Private Packagist提供托管和维护,两者的主要区别为Packagist的官网是托管...,托管的代码无需开源,仓库服务器可位于内网,提供更快、更高效的包代码托管服务。
可以配置多个仓库,Composer会自动找出最适合项目的依赖包。搜索包的流程如下检查当前项目是否配置额外仓库,有则优先在额外仓库中检索;无结果向上到全局配置中的额外仓库检索;未配置或搜索无结果的情况下,回退到默认的Packagist中央仓库检索。除非禁用了默认的仓库,Packagist中的包总会被检索到。因为这个原因,Composer推荐PHP开发人员将包托管在Packagist网站上,方便他人检索和引用。
配置仓库
有两种方法对Composer的仓库进行配置命令行和编辑配置文件。poser config是Composer配置的命令,可以用来配置项目或全局的仓库信息,例如
poser config [-g] repo.packagist poser
第二种方法是编辑配置文件。编辑项目的poser.json或~/.config/poser/config.json,增加repositories一项配置,例如
"repositories": { "packagist": { "type": "poser", "url": "https://packagist.phpposer." } }
以上配置使用 网站作为默认中央仓库。在大陆地区部署PHP项目,建议使用该仓库目录,能加速依赖包的下载。
仓库配置最重要的两个参数是type和url。type指明仓库的类型,url则指向具体网址。根据仓库的位置,常用的type可选值有
- poser,Composer包托管仓库,例如 Packagist中国全量镜像;
- vcs,版本控制管理系统,例如Github上的项目地址;
- pear,PEAR上的包;
- package,位于互联网上包;
- artifact,代码zip包合集;
- path,指向代码具体位置。
互联网上的仓库,type的常见值是poser和vcs;本地的项目,常见值是artifact和path。具体用例,可参考Composer官方文档。
掌握了仓库的概念和其配置,接下来我们创建自己的包。
创建自己的Composer包
创建一个Composer包只需两步1. 填写包描述信息;2. 写代码。本文创建一个hello-poser的包来演示创建过程。该包功能只有一个输出字符串“Hello, Composer!”。
Composer包的描述信息存放在poser.json文件中,可直接新建(或从其他项目拷贝)poser.json文件,手动填充必要的字段信息;也可以用poser init命令,交互式的输入包信息,生成poser.json文件后再补全其他字段信息。我们采取直接编辑文件的方式,在poser.json中输入如下内容
{ "name": "tlanyan/hello-poser", "description": "Hello, Composer!", "type": "library", "require": { "php": ">=7.0" }, "license": "MIT", "authors": [ { "name": "tlanyan", "email": "tlanyan@hotmail." } ], "minimum-stability": "stable", "autoload": { "psr-4": { "tlanyan\\": "src/" } } }
以上内容基本上是一个Composer包的必备字段。其他字段可参考Composer官网的poser.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规范。需注意文件的路径需与poser.json中autoload的值相匹配。
通过简单两步,我们创建的自己的Composer包。接下来在其他项目中引用该包。
引用Composer包
新建一个test项目,引用上文创建的包并查看效果,步骤如下
1.新建test文件夹,拷贝或者新建poser.json文件,配置如下
{ .... "require": { "tlanyan/hello-poser": "" }, "minimum-stability": "dev", "repositories": { "local": { "type": "path", "url": "/path/to/hello-poser" } }, .... }
配置文件需要注意两点 1. 如果hello-poser的poser.json文件没有version字段(或不是稳定版),minimum-stability值要是dev(默认是stable),否则无法安装; 2. 需添加自定义仓库,type值为path。
2.执行poser install -vvv安装依赖包,安装完成后vendor目录下生成tlanyan/hello-poser目录。
3.在test中新建Test.php文件,引用HelloComposer类
namespace test; require "vendor/autoload.php"; use tlanyan\HelloComposer; class Test { public static main() { HelloComposer::greet(); } } Test::main();
.执行Test.phpphp Test.php,输出"Hello, Composer!"。
通过配置Composer仓库,我们成功引用了创建的hello-poser包。测试没问题后,就可以发布到网上供其他人使用。狼蚁网站SEO优化简要说是发布流程。
发布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自由的引用和安装依赖包。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程