最实用的PHP Composer教程

分类:PHP 时间:

Composer是PHP用来管理依赖(dependency)关系的工具。Composer通常情况下通过composer.json文件来配置和管理依赖的。Composer允许你申明项目所依赖的代码库,Composer会在你的项目中为你安装他们。下面PHP程序员雷雪松详细的讲解下Composer的安装和常用命令。

Linux下安装Composer
1、安装Composer

1
2
3
4
5
6
[root@PHP ~]# curl -sS https://getcomposer.org/installer | php
All settings correct for using Composer
Downloading...

Composer (version 1.4.2) successfully installed to: /root/composer.phar
Use it: php composer.phar

2、如果不想加入全局命令,则只需要在安装的目录下面运行php composer.phar(php命令已经加入全局命令中)

1
2
[root@PHP ~]# php composer.phar
Composer version 1.4.2 2017-05-17 08:17:52

3、将Composer加入全局命令,后面我们就可以直接使用composer命令

1
2
3
[root@PHP ~]# mv composer.phar /usr/local/bin/composer
[root@PHP ~]# php composer.phar
Composer version 1.4.2 2017-05-17 08:17:52

Windows下安装Composer
下载并且运行 Composer-Setup.exe,安装完成后直接使用composer命令。

Composer实用命令
全局参数-可与每一个命令结合使用:
–verbose (-v): 增加反馈信息的详细度。
-v 表示正常输出。
-vv 表示更详细的输出。
-vvv 则是为了 debug。
–help (-h): 显示帮助信息。
–quiet (-q): 禁止输出任何信息。
–no-interaction (-n): 不要询问任何交互问题。
–working-dir (-d): 如果指定的话,使用给定的目录作为工作目录。
–profile: 显示时间和内存使用信息。
–ansi: 强制 ANSI 输出。
–no-ansi: 关闭 ANSI 输出。
–version (-V): 显示当前应用程序的版本信息。

1、初始化 init-以交互方式要求您填写一些信息,创建composer.json 文件

1
composer init

参数
–name: 包的名称。
–description: 包的描述。
–author: 包的作者。
–homepage: 包的主页。
–require: 需要依赖的其它包,必须要有一个版本约束。并且应该遵循 foo/bar:1.0.0 这样的格式。
–require-dev: 开发版的依赖包,内容格式与 –require 相同。
–stability (-s): minimum-stability 字段的值。

2、安装 install -从当前目录读取composer.json文件,处理了依赖关系并创建composer.lock 文件,并把其安装到 vendor 目录下

1
composer install

参数
–prefer-source: 下载包的方式有两种: source 和 dist。对于稳定版本 composer 将默认使用 dist 方式。而 source 表示版本控制源 。如果 –prefer-source 是被启用的,composer 将从 source 安装(如果有的话)。如果想要使用一个 bugfix 到你的项目,这是非常有用的。并且可以直接从本地的版本库直接获取依赖关系。
–prefer-dist: 与 –prefer-source 相反,composer 将尽可能的从 dist 获取,这将大幅度的加快在 build servers 上的安装。这也是一个回避 git 问题的途径,如果你不清楚如何正确的设置。
–dry-run: 如果你只是想演示而并非实际安装一个包,你可以运行 –dry-run 命令,它将模拟安装并显示将会发生什么。
–dev: 安装 require-dev 字段中列出的包(这是一个默认值)。
–no-dev: 跳过 require-dev 字段中列出的包。
–no-scripts: 跳过 composer.json 文件中定义的脚本。
–no-plugins: 关闭 plugins。
–no-progress: 移除进度信息,这可以避免一些不处理换行的终端或脚本出现混乱的显示。
–optimize-autoloader (-o): 转换 PSR-0/4 autoloading 到 classmap 可以获得更快的加载支持。特别是在生产环境下建议这么做,但由于运行需要一些时间,因此并没有作为默认值。

3、更新 update-获取依赖的最新版本,并且升级 composer.lock 文件,也可以更新固定依赖,直接在update跟包名。

1
composer update

参数
–prefer-source: 当有可用的包时,从 source 安装。
–prefer-dist: 当有可用的包时,从 dist 安装。
–dry-run: 模拟命令,并没有做实际的操作。
–dev: 安装 require-dev 字段中列出的包(这是一个默认值)。
–no-dev: 跳过 require-dev 字段中列出的包。
–no-scripts: 跳过 composer.json 文件中定义的脚本。
–no-plugins: 关闭 plugins。
–no-progress: 移除进度信息,这可以避免一些不处理换行的终端或脚本出现混乱的显示。
–optimize-autoloader (-o): 转换 PSR-0/4 autoloading 到 classmap 可以获得更快的加载支持。特别是在生产环境下建议这么做,但由于运行需要一些时间,因此并没有作为默认值。
–lock: 仅更新 lock 文件的 hash,取消有关 lock 文件过时的警告。
–with-dependencies 同时更新白名单内包的依赖关系,这将进行递归更新。

4、搜索 search- 从packagist.org 上搜索可用的依赖包

1
composer search

参数
–only-name (-N): 仅针对指定的名称搜索(完全匹配)。

5、展示 show-列出当前composer.json所有可用的软件包,也可以显示一个包的详细信息

1
composer show

参数
–installed (-i): 列出已安装的依赖包。
–platform (-p): 仅列出平台软件包(PHP 与它的扩展)。
–self (-s): 仅列出当前项目信息。

6、自我更新 self-update-更新Composer版本,或者回退到最后一次的版本

1
composer self-update

参数
–rollback (-r): 回滚到你已经安装的最后一个版本。
–clean-backups: 在更新过程中删除旧的备份,这使得更新过后的当前版本是唯一可用的备份。

7、获取帮助信息 help-获取composer用法和composer命令的帮助

1
composer help

Composer启用国内镜像
1、系统全局配置,将配置信息添加到Composer的全局配置文件config.json中。

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

2、单个项目配置,将配置信息添加到某个项目的composer.json文件中。

1
composer config repo.packagist composer https://packagist.phpcomposer.com

也可以将以下信息手工添加到Composer的全局配置文件config.json或者某个项目的composer.json文件。

1
2
3
4
5
6
"repositories": {
"packagist": {
"type": "composer",
"url": "https://packagist.phpcomposer.com"
}
}

标签:
来源:最实用的PHP Composer教程

7 评论 “最实用的PHP Composer教程

    bandwagonhost 评论:
    2017年8月9日 下午2:23

    朋友 交换链接吗

    美股指数 评论:
    2017年8月21日 下午9:34

    秒赞不是偶然,是一种态度!

    stone 评论:
    2017年9月7日 下午5:54

    一本好书

    stone0 评论:
    2017年9月7日 下午6:03

    一本好书0

    stone5 评论:
    2017年9月7日 下午6:05

    一本好书5

    stone6 评论:
    2017年9月7日 下午6:06

    一本好书6

    essay代写 评论:
    2017年9月19日 下午4:46

    很好的书

发表评论

电子邮件地址不会被公开。 必填项已用*标注