composer updates specified dependency packages
composer updates the specified dependency package
compoesr's require/update can update the specified dependency package (upgrade /downgrade).
require is more flexible. If it is not installed, it will be installed. If it is installed, it will be upgraded or downgraded according to the version number passed in.
Update cannot pass a new version number on the command line. You need to manually specify the new version number in composer.json and then execute the update command.
composer require google/protobuf --ignore-platform-reqs -vvv
Related recommendations: [composer tutorial]
require command
Example
// 安装包 composer require hashids/hashids:2.0.0 // 已安装 升级 composer require hashids/hashids:3.0.0 // 已安装 降级 composer require hashids/hashids:2.0.4
update command
The update command cannot specify the package version number in the command line, and you need to manually modify the composer.json file
// 安装包 composer require hashids/hashids:2.0.0
Incorrect usage
composer update hashids/hashids:3.0.0
Correct usage example
vim composer.json "require": { "hashids/hashids": "3.0.0" }, :wq #升级到3.0.0 composer update hashids/hashids vim composer.json "require": { "hashids/hashids": "2.0.4" }, :wq #降级到2.0.4 composer update hashids/hashids
At the same time, if we edit and update the version numbers of multiple packages, we cannot use the
composer update package1 composer update package2 composer update package3
method to update them sequentially, because composer will verify the integrity of the configuration file json vs Lock, you specified that you want me to update A, but the version of B is inconsistent in json and lock, but you don't want me to update it. This is problematic.
At this time, you can only use composer update to globally update dependencies. Note that this is an update operation for global packages. Some packages that you have not changed but use a version number range may also be updated and upgraded. Please use with caution!
install command
install can be used to install dependencies for the first time after project initialization, and the version number in composer.lock
will be read first , to ensure the consistency of package versions in collaborative development as much as possible.
The package version record that exists in composer.lock is equivalent to executing composer require packageName:versionNo
, and the one that does not exist is equivalent to executing composer update packageName with versionRule in composer.json
.
When we collaborate on development, A installs a new dependency package locally, or updates a dependency package, which will be written to composer.lock/composer.json. A uploads it to the warehouse, and B pulls it locally. , a composer install should be executed to synchronize the team's version changes.
So during collaborative development, we recommend uploading composer.lock/composer.json
to the remote warehouse at the same time.
Version number range
大于/大于等于:>1.2.3 >=1.2.3 小于/小于等于:<1.2.3 <=1.2.3 确切的版本号:1.2.3 ~1.2.3: 1.2.3 <= version < 1.3 ^1.2.3: 1.2.3 <= version < 2.0 { "php": ">=7.0", "ext-swoole": ">=4.0.0", "lib-curl": ">=7.29.0" }
The above is the detailed content of composer updates specified dependency packages. For more information, please follow other related articles on the PHP Chinese website!

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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



When developing websites using CraftCMS, you often encounter resource file caching problems, especially when you frequently update CSS and JavaScript files, old versions of files may still be cached by the browser, causing users to not see the latest changes in time. This problem not only affects the user experience, but also increases the difficulty of development and debugging. Recently, I encountered similar troubles in my project, and after some exploration, I found the plugin wiejeben/craft-laravel-mix, which perfectly solved my caching problem.

I encountered a tricky problem when developing a new Laravel project: how to quickly build a fully functional and easy-to-manage content management system (CMS). I tried multiple solutions, but all gave up because of complex configuration and inconvenient maintenance. Until I discovered the LaravelCMS package mki-labs/espresso, which not only simple to install, but also provides powerful functions and intuitive management interface, which completely solved my problem.

I encountered a common but tricky problem when developing a large PHP project: how to effectively manage and inject dependencies. Initially, I tried using global variables and manual injection, but this not only increased the complexity of the code, it also easily led to errors. Finally, I successfully solved this problem by using the PSR-11 container interface and with the power of Composer.

During development, HTTP requests are often required, which may be to get data, send data, or interact with external APIs. However, when faced with complex network environments and changing request requirements, how to efficiently handle HTTP requests becomes a challenge. I have encountered a problem in a project: I need to send requests to different APIs frequently, and log the requests to facilitate subsequent debugging and analysis. After trying several methods, I discovered the yiche/http library. It not only simplifies the processing of HTTP requests, but also provides dynamic logging functions, greatly improving development efficiency.

I'm having a tough problem when developing a complex web application: how to effectively handle JavaScript errors and log them. I tried several methods, but none of them could meet my needs until I discovered the library dvasilenko/alterego_tools. I easily solved this problem through the installation of this library through Composer and greatly improved the maintainability and stability of the project. Composer can be learned through the following address: Learning address

Article summary: This article provides detailed step-by-step instructions to guide readers on how to easily install the Laravel framework. Laravel is a powerful PHP framework that speeds up the development process of web applications. This tutorial covers the installation process from system requirements to configuring databases and setting up routing. By following these steps, readers can quickly and efficiently lay a solid foundation for their Laravel project.

When developing a Laravel application, I encountered a common but difficult problem: how to improve the security of user accounts. With the increasing complexity of cyber attacks, a single password protection is no longer enough to ensure the security of users' data. I tried several methods, but the results were not satisfactory. Finally, I installed the wiebenieuwenhuis/laravel-2fa library through Composer and successfully added two-factor authentication (2FA) to my application, greatly improving security.

In project development, it is often necessary to create command-line tools to simplify daily tasks or automate processes. However, creating a command line interface that is beautiful and easy to test is not easy. Recently, I encountered this problem while developing a project that requires command line tools. After some exploration, I found the Symfony/Console library, which greatly simplifies the creation process of command line interfaces.
