Table of Contents
PHP 开发者该知道的 5 个 Composer 小技巧
1. 仅更新单个库
2. 不编辑 composer.json的情况下安装库
3. 派生很容易
4. 考虑缓存, dist包优先
5. 若要修改,源代码优先
为生产环境作准备
版本信息

Composer 教程

Jun 23, 2016 pm 01:14 PM

Composer是 PHP 用来管理依赖(dependency)关系的工具。你可以在自己的项目中声明所依赖的外部工具库(libraries),Composer 会帮你安装这些依赖的库文件。

本教程内容来源于 Composer 中文网

英文官网: https://getcomposer.org/

更新日期 更新内容
2015-04-30 Composer 中文版

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

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

1. 仅更新单个库

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

composer update foo/bar  
Copy after login

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

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.  
Copy after login

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

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

$ composer update nothingLoading composer repositories with package information  Updating dependencies  Nothing to install or update  Writing lock file  Generating autoload files  
Copy after login

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

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

composer update --lock  
Copy after login

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

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

composer require "foo/bar:1.0.0"  
Copy after login

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

$ composer init --require=foo/bar:1.0.0 -n$ cat composer.json{    "require": {        "foo/bar": "1.0.0"    }}
Copy after login

3. 派生很容易

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

composer create-project doctrine/orm path 2.2.0  
Copy after login

这会自动克隆仓库,并检出指定的版本。克隆库的时候用这个命令很方便,不需要搜寻原始的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选项来显示执行时间):

$ composer init --require="twig/twig:1.*" -n --profileMemory usage: 3.94MB (peak: 4.08MB), time: 0s$ composer install --profileLoading composer repositories with package information  Installing dependencies    - Installing twig/twig (v1.12.2)    Downloading: 100%Writing lock file  Generating autoload files  Memory usage: 10.13MB (peak: 12.65MB), time: 4.71s$ rm -rf vendor$ composer install --profileLoading composer repositories with package information  Installing dependencies from lock file    - Installing twig/twig (v1.12.2)    Loading from cacheGenerating autoload files  Memory usage: 4.96MB (peak: 5.57MB), time: 0.45s  
Copy after login

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

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

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

composer update symfony/yaml --prefer-source  
Copy after login

接下来你可以修改文件:

composer status -v  You have changes in the following dependencies:  /path/to/app/vendor/symfony/yaml/Symfony/Component/Yaml:    M Dumper.php
Copy after login

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

$ composer updateLoading composer repositories with package information  Updating dependencies    - Updating symfony/symfony v2.2.0 (v2.2.0- => v2.2.0)    The package has modified files:    M Dumper.php    Discard changes [y,n,v,s,?]?
Copy after login

为生产环境作准备

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

composer dump-autoload --optimize  
Copy after login

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

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

原文地址: 5 features to know about Composer PHP

译文地址: PHP 开发者该知道的 5 个 Composer 小技巧

版本信息

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

语言/框架 版本信息
PHP 5.3.2 以上
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Working with Flash Session Data in Laravel Working with Flash Session Data in Laravel Mar 12, 2025 pm 05:08 PM

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

cURL in PHP: How to Use the PHP cURL Extension in REST APIs cURL in PHP: How to Use the PHP cURL Extension in REST APIs Mar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Simplified HTTP Response Mocking in Laravel Tests Simplified HTTP Response Mocking in Laravel Tests Mar 12, 2025 pm 05:09 PM

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 Best PHP Chat Scripts on CodeCanyon 12 Best PHP Chat Scripts on CodeCanyon Mar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Explain the concept of late static binding in PHP. Explain the concept of late static binding in PHP. Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

PHP Logging: Best Practices for PHP Log Analysis PHP Logging: Best Practices for PHP Log Analysis Mar 10, 2025 pm 02:32 PM

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

HTTP Method Verification in Laravel HTTP Method Verification in Laravel Mar 05, 2025 pm 04:14 PM

Laravel simplifies HTTP verb handling in incoming requests, streamlining diverse operation management within your applications. The method() and isMethod() methods efficiently identify and validate request types. This feature is crucial for building

Discover File Downloads in Laravel with Storage::download Discover File Downloads in Laravel with Storage::download Mar 06, 2025 am 02:22 AM

The Storage::download method of the Laravel framework provides a concise API for safely handling file downloads while managing abstractions of file storage. Here is an example of using Storage::download() in the example controller:

See all articles