安装
- 下载composer安装器
1 | php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" |
- 校验安装包是否正确(可选,以v1.9.3为例)
1 | php -r "if (hash_file('sha384', 'composer-setup.php') === 'e0012edf3e80b6978849f5eff0d4b4e4c79ff1609dd1e613307e16318854d24ae64f26d17af3ef0bf7cfb710ca74755a') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;" |
注意hash值有版本差异
- 安装composer
1 | php composer-setup.php --install-dir=bin |
- 卸载安装包(可选)
1 | php -r "unlink('composer-setup.php');" |
- windows系统中 使用composer命令(可选)
新建 composer.bat 文件,内容为 @php “%~dp0composer.phar” %*
环境变量中添加composer.bat文件路径
- 国内镜像切换(可选)
1 | composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/ |
更多参考 https://getcomposer.org/download/
使用
常用命令
install 命令
要使用 Composer,我们需要先在项目的目录下创建一个 composer.json 文件,文件描述了项目的依赖关系。
文件格式如下:
1 | { |
以上文件说明我们需要下载从 1.2 开始的任何版本的 monolog。
接下来只要运行以下命令即可安装依赖包: 如何发布包?
composer install
require 命令
除了使用 install 命令外,我们也可以使用 require 命令快速的安装一个依赖而不需要手动在 composer.json 里添加依赖信息:
1 | composer require monolog/monolog |
Composer 会先找到合适的版本,然后更新composer.json文件,在 require 那添加 monolog/monolog 包的相关信息,再把相关的依赖下载下来进行安装,最后更新 composer.lock 文件并生成 php 的自动加载文件。
update 命令
update 命令用于更新项目里所有的包,或者指定的某些包:
1 | 更新所有依赖 |
需要注意的时,包能升级的版本会受到版本约束的约束,包不会升级到超出约束的版本的范围。例如如果 composer.json 里包的版本约束为 ^1.10,而最新版本为 2.0。那么 update 命令是不能把包升级到 2.0 版本的,只能最高升级到 1.x 版本。关于版本约束请看后面的介绍。
remove 命令
remove 命令用于移除一个包及其依赖(在依赖没有被其他包使用的情况下),如果依赖被其他包使用,则无法移除:
1 | composer remove monolog/monolog |
search 命令
search 命令可以搜索包:
1 | composer search monolog |
该命令会输出包及其描述信息,如果只想输出包名可以使用 –only-name 参数:
1 | composer search --only-name monolog |
show 命令
show 命令可以列出当前项目使用到包的信息:
1 | 列出所有已经安装的包 |
基本约束
精确版本
我们可以告诉 Composer 安装的具体版本,例如:1.0.2,指定 1.0.2 版本。
范围
通过使用比较操作符来指定包的范围。这些操作符包括:>
,>=
,<
,<=
,!=
。
你可以定义多个范围,使用空格或者逗号 , 表示逻辑上的与,使用双竖线 || 表示逻辑上的或。其中与的优先级会大于或。 实例:
- >=1.0
- >=1.0 <2.0
- >=1.0 <1.1 || >=1.2
我们也可以通过使用连字符 - 来指定版本范围。
连字符的左边表明了 >=
的版本,如果右边的版本不是完整的版本号,则会被使用通配符进行补全。例如 1.0 - 2.0
等同于 >=1.0.0
<2.1
(2.0相当于2.0.*
),而1.0.0 - 2.1.0
则等同于 >=1.0.0
<=2.1.0
。
通配符
可以使用通配符来设置版本。1.0.*
相当于 >=1.0
<1.1
。
例子:1.0.*
波浪号 ~
我们先通过后面这个例子去解释 ~
操作符的用法:~1.2
相当于 >=1.2
<2.0.0
,而 ~1.2.3
相当于 >=1.2.3
<1.3.0
。对于使用Semantic Versioning作为版本号标准的项目来说,这种版本约束方式很实用。例如 ~1.2
定义了最小的小版本号,然后你可以升级2.0以下的任何版本而不会出问题,因为按照Semantic Versioning的版本定义,小版本的升级不应该有兼容性的问题。简单来说,~
定义了最小的版本,并且允许版本的最后一位版本号进行升级(没懂得话,请再看一边前面的例子)。
例子:~1.2
需要注意的是,如果 ~
作用在主版本号上,例如 ~1
,按照上面的说法,Composer可以安装版本1以后的主版本,但是事实上是 ~1
会被当作 ~1.0
对待,只能增加小版本,不能增加主版本。
折音号 ^
^操作符的行为跟Semantic Versioning有比较大的关联,它允许升级版本到安全的版本。例如,^1.2.3相当于>=1.2.3 <2.0.0,因为在2.0版本前的版本应该都没有兼容性的问题。而对于1.0之前的版本,这种约束方式也考虑到了安全问题,例如^0.3会被当作>=0.3.0 <0.4.0对待。
例子:^1.2.3
版本稳定性
如果你没有显式的指定版本的稳定性,Composer会根据使用的操作符,默认在内部指定为-dev或者-stable。例如:
约束 | 内部约束 |
---|---|
1.2.3 | =1.2.3.0-stable |
>1.2 | >1.2.0.0-stable |
>=1.2 | >=1.2.0.0-dev |
>=1.2-stable | >=1.2.0.0-stable |
<1.3 | <1.3.0.0-dev |
<=1.3 | <=1.3.0.0-stable |
1 - 2 | >=1.0.0.0-dev <3.0.0.0-dev |
~1.3 | >=1.3.0.0-dev <2.0.0.0-dev |
1.4.* | >=1.4.0.0-dev <1.5.0.0-dev |
例子:1.0 - 2.0
如果你想指定版本只要稳定版本,你可以在版本后面添加后缀 -stable
。
minimum-stability 配置项定义了包在选择版本时对稳定性的选择的默认行为。默认是stable
。它的值如下(按照稳定性排序):dev
,alpha
,beta
,RC
和stable
。除了修改这个配置去修改这个默认行为,我们还可以通过稳定性标识(例如@stable
和@dev
)来安装一个相比于默认配置不同稳定性的版本。例如:
1 | { |