This article mainly introduces 5 Composer tips that PHP developers should know. Friends in need can refer to them
Composer is a new generation of PHP dependency management tool. For its introduction and basic usage, you can read this article "A New Era of Composer PHP Dependency Management". This article introduces five tips for using Composer, hoping to bring convenience to your PHP development.
1. Only update a single library
You only want to update a specific library and don’t want to update all its dependencies. It’s very simple:
composer update foo/bar
In addition, this trick can also be used to solve the "warning message problem". You must have seen warning messages like this:
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.
Oh, what went wrong? Don't panic! If you edit composer.json
, you should see a message like this. For example, if you add or update details such as a library description, author, more parameters, or even just a space, it will change the md5sum of the file. Then Composer will warn you that the hash value is different from the one recorded in composer.lock
.
So what should we do? The update
command can update the lock file, but if you only add some descriptions, it should not update any libraries. In this case, just update nothing
:
$ composer update nothing Loading composer repositories with package information Updating dependencies Nothing to install or update Writing lock file Generating autoload files
This way Composer will not update the library, but it will update composer.lock
. Note that nothing
is not a keyword of the update
command. There is just no nothing
result caused by this package. If you type foobar
, the result will be the same.
If the Composer version you are using is new enough, you can use the --lock
option directly:
composer update --lock
2. No editing In the case of composer.json
, when installing the library
you may find it too troublesome to modify composer.json
every time you install a library, then you can use the require
command directly.
composer require "foo/bar:1.0.0"
This method can also be used to quickly open a new project. The init
command has the --require
option, which can automatically write composer.json
: (note that we use -n
so that we don’t have to answer the question)
$ composer init --require=foo/bar:1.0.0 -n $ cat composer.json { "require": { "foo/bar": "1.0.0" } }
3. It is easy to derive
During initialization, have you tried the create-project
command?
composer create-project doctrine/orm path 2.2.0
This will automatically clone the repository and check out the specified version. This command is very convenient to use when cloning a library, as there is no need to search for the original URI.
4. Consider caching, dist
package priority
Composer from the past year will automatically archive the dist
package you downloaded. By default, the dist
package is used for tagged versions, such as "symfony/symfony": "v2.1.4"
, or wildcards or version ranges, "2.1.*"
or ">=2.2, (if you use <code>stable
as your minimum-stability
). The
dist package can also be used for branches such as dev-master
. Github allows you to download the compressed package of a certain git reference. To force the use of a tarball instead of cloning the source code, you can use the install
option of update
and --prefer-dist
.
Here is an example (I used the --profile
option to show execution time):
$ composer init --require="twig/twig:1.*" -n --profile Memory usage: 3.94MB (peak: 4.08MB), time: 0s $ composer install --profile Loading 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 --profile Loading composer repositories with package information Installing dependencies from lock file - Installing twig/twig (v1.12.2) Loading from cache Generating autoload files Memory usage: 4.96MB (peak: 5.57MB), time: 0.45s
Here, twig/twig:1.12.2
The compressed package is saved in ~/.composer/cache/files/twig/twig/1.12.2.0-v1.12.2.zip
. Use it directly when reinstalling the package.
5. If you want to modify, source code first
When you need to modify the library, cloning the source code is more convenient than downloading the package. You can use --prefer-source
to force selection of cloned source code.
composer update symfony/yaml --prefer-source
Next you can modify the file:
composer status -v You have changes in the following dependencies: /path/to/app/vendor/symfony/yaml/Symfony/Component/Yaml: M Dumper.php
When When you try to update a modified library, Composer will remind you and ask whether to abandon the modification:
$ composer update Loading 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,?]?
Prepare for production environment
Finally, when deploying code to the production environment, don’t forget to optimize automatic loading:
composer dump-autoload --optimize
You can do this when installing the package Use --optimize-autoloader
similarly. Without this option, you may see a 20% to 25% performance loss.
If you need help or want to know the details of a certain command, you can read the official documentation or Chinese documentation, or you can check out this interactive cheat sheet made by JoliCode.
Original address: 5 features to know about Composer PHP
Translation address: 5 Composer tips that PHP developers should know
Composer is a new generation of PHP dependency management tool. For its introduction and basic usage, you can read this article "A New Era of Composer PHP Dependency Management". This article introduces five tips for using Composer, hoping to bring convenience to your PHP development.
1. Only update a single library
You only want to update a specific library and don’t want to update all its dependencies. It’s very simple:
composer update foo/bar
In addition, this trick can also be used to solve the "warning message problem". You must have seen warning messages like this:
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.
Oh, what went wrong? Don't panic! If you edit composer.json
, you should see a message like this. For example, if you add or update details such as a library description, author, more parameters, or even just a space, it will change the md5sum of the file. Then Composer will warn you that the hash value is different from the one recorded in composer.lock
.
So what should we do? The update
command can update the lock file, but if you only add some descriptions, it should not update any libraries. In this case, just update nothing
:
$ composer update nothing Loading composer repositories with package information Updating dependencies Nothing to install or update Writing lock file Generating autoload files
This way Composer will not update the library, but it will update composer.lock
. Note that nothing
is not a keyword of the update
command. There is just no nothing
result caused by this package. If you type foobar
, the result will be the same.
If the Composer version you are using is new enough, you can use the --lock
option directly:
composer update --lock
2. No editing In the case of composer.json
, when installing the library
you may find it too troublesome to modify composer.json
every time you install a library, then you can use the require
command directly.
composer require "foo/bar:1.0.0"
This method can also be used to quickly open a new project. The init
command has the --require
option, which can automatically write composer.json
: (note that we use -n
so that we don’t have to answer the question)
$ composer init --require=foo/bar:1.0.0 -n $ cat composer.json { "require": { "foo/bar": "1.0.0" } }
3. It is easy to derive
During initialization, have you tried the create-project
command?
composer create-project doctrine/orm path 2.2.0
This will automatically clone the repository and check out the specified version. This command is very convenient to use when cloning a library, as there is no need to search for the original URI.
4. Consider caching, dist
package priority
Composer from the past year will automatically archive the dist
package you downloaded. By default, the dist
package is used for tagged versions, such as "symfony/symfony": "v2.1.4"
, or wildcards or version ranges, "2.1.*"
or ">=2.2, (if you use <code>stable
as your minimum-stability
). The
dist package can also be used for branches such as dev-master
. Github allows you to download the compressed package of a certain git reference. To force the use of a tarball instead of cloning the source code, you can use the install
option of update
and --prefer-dist
.
Here is an example (I used the --profile
option to show execution time):
$ composer init --require="twig/twig:1.*" -n --profile Memory usage: 3.94MB (peak: 4.08MB), time: 0s $ composer install --profile Loading 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 --profile Loading composer repositories with package information Installing dependencies from lock file - Installing twig/twig (v1.12.2) Loading from cache Generating autoload files Memory usage: 4.96MB (peak: 5.57MB), time: 0.45s
Here, twig/twig:1.12.2
The compressed package is saved in ~/.composer/cache/files/twig/twig/1.12.2.0-v1.12.2.zip
. Use it directly when reinstalling the package.
5. If you want to modify, source code first
When you need to modify the library, cloning the source code is more convenient than downloading the package. You can use --prefer-source
to force selection of cloned source code.
composer update symfony/yaml --prefer-source
Next you can modify the file:
composer status -v You have changes in the following dependencies: /path/to/app/vendor/symfony/yaml/Symfony/Component/Yaml: M Dumper.php
When When you try to update a modified library, Composer will remind you and ask whether to abandon the modification:
$ composer update Loading 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,?]?
Prepare for production environment
Finally, when deploying code to the production environment, don’t forget to optimize automatic loading:
composer dump-autoload --optimize
You can do this when installing the package Use --optimize-autoloader
similarly. Without this option, you may see a 20% to 25% performance loss.
If you need help or want to know the details of a certain command, you can read the official documentation or Chinese documentation, or you can check out this interactive cheat sheet made by JoliCode.

本文由composer教程栏目给大家介绍关于在Debian11上是怎么一步步安装,以及使用Composer的 ,非常详细哦~希望对需要的朋友有所帮助!

Composer是PHP的依赖管理工具,它允许开发者将第三方库和框架与自己的项目进行集成。它的主要功能包括:1、依赖管理;2、版本控制;3、自动加载;4、扩展开发;5、集成其他工具。它简化了PHP项目的依赖管理过程,确保项目的稳定性和可维护性。通过使用Composer,开发者可以更加高效地管理自己的项目和集成第三方库和框架。

composer修改php路径的方法:1、搜索“composer.bat”并复制到项目文件夹;2、编辑“composer.bat”,将内容修改为“@ECHO OFF php "%~dp0composer.phar" %*”即可。

在PHP开发中,我们经常要处理各种依赖包,这些依赖包可能是其他开发者编写的PHP库文件,也可能是一些第三方工具和框架。为了方便管理这些依赖包,我们可以使用Composer来进行相关的安装和管理工作。Composer是一个开源的PHP依赖管理工具,它可以帮助我们自动化安装、更新和卸载PHP依赖包。通过Composer,我们可以轻松地管理我们应用中的不同依赖,同

随着PHP的日益流行,PHP开发人员面临着许多挑战,其中包括代码管理、可重用性和依赖性管理。这些问题可以使用包管理器来解决,而Composer是PHP最受欢迎的包管理器之一。在本文中,我们将探讨使用Composer和PHP包管理器的最佳实践,从而提高您的PHP开发效率和代码质量。何为Composer?Composer是一款PHP包管理器,它可以轻松管理PHP

Composer是一个PHP的依赖管理工具,可以帮助开发者有效地管理项目中的依赖关系。通过Composer,我们可以轻松地引入第三方库、框架以及其他项目所需的各种资源。创建一个Composer项目非常简单,只需按照以下步骤进行操作:首先需要确保在本地已经安装了Composer。可以在终端中运行composer-v命令来确认是否已经安装成功。在项目的根目录中

composer是PHP的依赖管理工具,可以方便地安装、更新和管理项目所需的第三方库和依赖。本文将介绍composer的安装与使用,并提供详细的代码示例。一、安装Composer要使用composer,首先需要将其安装到本地开发环境中。以下演示了在Windows系统中安装composer的步骤:打开Composer的官方网站(https://getcompo

要保存 Composer 动画,可以使用 Lottie 文件格式,具体步骤为:导出为 JSON 文件;使用 Lottie 工具创建 Lottie 文件;从 Lottie 文件导出为多种格式,包括 JSON、GIF、MP4、SWF、HTML。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

WebStorm Mac version
Useful JavaScript development tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
