课程表

Composer课程

工具箱
速查手册

Composer教程

当前位置:免费教程 » 软件/图像 » Composer
Composer

Composer是 PHP 用来管理依赖(dependency)关系的工具。

你可以在自己的项目中声明所依赖的外部工具库(libraries),Composer 会帮你安装这些依赖的库文件。

Composer之于PHP,类似Maven之于Java,pip之于Python,npm之于Nodejs。

开始学习Composer!


相关链接

PHP 开发者该知道的 5 个 Composer 小技巧

Composer 是新一代的PHP依赖管理工具。其介绍和基本用法可以看这篇《Composer PHP依赖管理的新时代》。本文介绍使用Composer的五个小技巧,希望能给你的PHP开发带来方便。

1. 仅更新单个库

只想更新某个特定的库,不想更新它的所有依赖,很简单:

  1. composer update foo/bar

此外,这个技巧还可以用来解决“警告信息问题”。你一定见过这样的警告信息:

  1. Warning: The lock file is not up to date with the latest changes in composer.json, you may be getting outdated dependencies, run update to update them.

擦,哪里出问题了?别惊慌!如果你编辑了composer.json,你应该会看到这样的信息。比如,如果你增加或更新了细节信息,比如库的描述、作者、更多参数,甚至仅仅增加了一个空格,都会改变文件的md5sum。然后Composer就会警告你哈希值和composer.lock中记载的不同。

那么我们该怎么办呢?update命令可以更新lock文件,但是如果仅仅增加了一些描述,应该是不打算更新任何库。这种情况下,只需update nothing:

  1. $ composer update nothing
  2. Loading composer repositories with package information
  3. Updating dependencies
  4. Nothing to install or update
  5. Writing lock file
  6. Generating autoload files

这样一来,Composer不会更新库,但是会更新composer.lock。注意nothing并不是update命令的关键字。只是没有nothing 这个包导致的结果。如果你输入foobar,结果也一样。

如果你用的Composer版本足够新,那么你可以直接使用--lock选项:

  1. composer update --lock

2. 不编辑composer.json的情况下安装库

你可能会觉得每安装一个库都需要修改composer.json太麻烦,那么你可以直接使用require命令。

  1. composer require "foo/bar:1.0.0"

这个方法也可以用来快速地新开一个项目。init命令有--require选项,可以自动编写composer.json:(注意我们使用-n,这样就不用回答问题)

  1. $ composer init --require=foo/bar:1.0.0 -n
  2. $ cat composer.json
  3. {
  4. "require": {
  5. "foo/bar": "1.0.0"
  6. }
  7. }

3. 派生很容易

初始化的时候,你试过create-project命令么?

  1. composer create-project doctrine/orm path 2.2.0

这会自动克隆仓库,并检出指定的版本。克隆库的时候用这个命令很方便,不需要搜寻原始的URI了。

4. 考虑缓存,dist包优先

最近一年以来的Composer会自动存档你下载的dist包。默认设置下,dist包用于加了tag的版本,例如"symfony/symfony": "v2.1.4",或者是通配符或版本区间,"2.1.*"或">=2.2,<2.3-dev"(如果你使用stable作为你的minimum-stability)。

dist包也可以用于诸如dev-master之类的分支,Github允许你下载某个git引用的压缩包。为了强制使用压缩包,而不是克隆源代码,你可以使用install和update的--prefer-dist选项。

下面是一个例子(我使用了--profile选项来显示执行时间):

  1. $ composer init --require="twig/twig:1.*" -n --profile
  2. Memory usage: 3.94MB (peak: 4.08MB), time: 0s
  3. $ composer install --profile
  4. Loading composer repositories with package information
  5. Installing dependencies
  6. - Installing twig/twig (v1.12.2)
  7. Downloading: 100%
  8. Writing lock file
  9. Generating autoload files
  10. Memory usage: 10.13MB (peak: 12.65MB), time: 4.71s
  11. $ rm -rf vendor
  12. $ composer install --profile
  13. Loading composer repositories with package information
  14. Installing dependencies from lock file
  15. - Installing twig/twig (v1.12.2)
  16. Loading from cache
  17. Generating autoload files
  18. Memory usage: 4.96MB (peak: 5.57MB), time: 0.45s

这里,twig/twig:1.12.2的压缩包被保存在~/.composer/cache/files/twig/twig/1.12.2.0-v1.12.2.zip。重新安装包时直接使用。

5. 若要修改,源代码优先

当你需要修改库的时候,克隆源代码就比下载包方便了。你可以使用--prefer-source来强制选择克隆源代码。

  1. composer update symfony/yaml --prefer-source

接下来你可以修改文件:

  1. composer status -v
  2. You have changes in the following dependencies:
  3. /path/to/app/vendor/symfony/yaml/Symfony/Component/Yaml:
  4. M Dumper.php

当你试图更新一个修改过的库的时候,Composer会提醒你,询问是否放弃修改:

  1. $ composer update
  2. Loading composer repositories with package information
  3. Updating dependencies
  4. - Updating symfony/symfony v2.2.0 (v2.2.0- => v2.2.0)
  5. The package has modified files:
  6. M Dumper.php
  7. Discard changes [y,n,v,s,?]?

为生产环境作准备

最后提醒一下,在部署代码到生产环境的时候,别忘了优化一下自动加载:

  1. composer dump-autoload --optimize

安装包的时候可以同样使用--optimize-autoloader。不加这一选项,你可能会发现20%到25%的性能损失

如果你需要帮助,或者想要了解某个命令的细节,你可以阅读官方文档或者中文文档,也可以查看JoliCode做的这个交互式备忘单

原文地址:5 features to know about Composer PHP译文地址:PHP 开发者该知道的 5 个 Composer 小技巧

版本信息

书中演示代码基于以下版本:

语言/框架版本信息
PHP5.3.2 以上

社区

已经有很多人在使用 composer,也有很多人为它做出了贡献。

贡献

如果你想为 composer 做出自己的贡献,请阅读 README

最重要的原则介绍如下:

所有贡献的代码 - 包括那些具有提交权限的人 - 必须通过一个 pull request 提交,并在合并前由核心开发人员的核准。

Fork 这个项目,创建一个特性分支,并给我们发送 pull request。

为了与基础代码保持一致,你应该确保代码遵循 编码规范

IRC频道 / 邮件列表

邮件列表:用户支持 / 开发者

irc.freenode.org 上的 IRC 频道:#composer (用户)/ #composer-dev(开发者)。

Stack Overflow 上有越来越多 Composer 相关问题的收藏。

转载本站内容时,请务必注明来自W3xue。
部分原创内容未经授权禁止转载,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号