0

0

composer怎么升级Composer自身_composer怎么更新到最新版本【方案】

冰火之心

冰火之心

发布时间:2026-03-11 18:09:19

|

706人浏览过

|

来源于php中文网

原创

composer 2.5.0+ 已彻底移除 self-update 命令,必须通过官方安装脚本覆盖重装,该脚本内置 sha-384 和 gpg 双重校验以确保二进制安全可信。

composer怎么升级composer自身_composer怎么更新到最新版本【方案】

composer self-update 已失效:2.5.0+ 版本不再支持该命令

如果你运行 composer self-update 却收到 Command "self-update" is not defined,这不是权限或网络问题,而是官方从 Composer 2.5.0 起彻底移除了这个命令。它不是“坏了”,是被主动废弃了——Composer 团队改用「重装式更新」统一管理二进制生命周期。

这意味着你不能再“升级”一个已存在的 composer.phar,只能用新版本覆盖旧文件。所有依赖签名验证、SHA-384 校验、安装路径控制等逻辑,现在都收束到官方安装脚本里。

  • 执行 composer --version,若显示 2.5.0 或更高(如 2.7.7),说明你当前已是新版,但旧命令已不可用
  • 若仍显示 1.x(如 1.10.22),必须重装,self-update 对 v1 完全无效
  • 某些 Docker 镜像或宝塔面板预装的 Composer 可能是硬链接或静态二进制,self-update 必然失败,别白试

正确更新方式:用官方安装脚本覆盖重装

安全、可靠、带完整校验的更新,只有一条路:下载并执行官方安装器。它会自动校验 SHA-384 签名,确保你拿到的是未篡改的正版二进制。

推荐命令(Linux/macOS):

php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
php -r "if (hash_file('sha384', 'composer-setup.php') === 'dac665fdc30fdd8ec78b38b9800061b4150413ff2e3b6f88543c636f7cd84f6db9189d43a81e5503cda447da73c7e5b6dc97f') { echo 'Installer verified'; } else { echo 'Installer corrupt'; unlink('composer-setup.php'); } echo PHP_EOL;"
sudo php composer-setup.php --install-dir=/usr/local/bin --filename=composer
php -r "unlink('composer-setup.php');"

简写版(适合信任环境,跳过手动校验):

银河易创
银河易创

一站式AIGC创作平台,集成GPT-3.5、GPT-4、文心一言等对话模型、Midjourney、DallE等绘画工具、AI音乐、AI视频和AI PPT等功能!

下载
curl -sS https://getcomposer.org/installer | php -- --filename=composer --install-dir=/usr/local/bin
  • --install-dir 必须是你 $PATH 中的可写目录;若无 sudo 权限,改用 --install-dir=$HOME/bin 并确保该路径已加入 $PATH
  • Windows 用户请用管理员权限运行 PowerShell,命令类似,但路径用 C:\ProgramData\ComposerSetup\bin 等用户可写位置
  • 国内用户若卡在 curlcopy(),可先设置镜像源临时加速:export COMPOSER_HOME=~/.composer,再运行上述命令

为什么不能手动下载 composer.phar 直接替换?

有人图省事,直接去官网下载 composer.phar 放进 /usr/local/bin,这很危险。因为官方不再提供独立、带签名的 .phar 文件下载入口;你从非脚本渠道拿到的文件,无法验证是否被中间人篡改或镜像源污染。

而官方安装脚本内建了两层防护:

  • 下载的 installer 自身有硬编码 SHA-384 值校验(见上例中那串长哈希)
  • 安装器再从 CDN 下载最终 composer.phar,并用 GPG 公钥二次签名验证(Composer 2.2+ 默认启用)
  • 跳过任一环,就等于放弃供应链安全底线

尤其在 CI/CD 流水线或共享服务器上,用未校验的二进制可能引入隐蔽风险。

更新后必须验证的三件事

重装完别急着跑项目,先确认三个关键点是否对齐:

  • 运行 composer --version,输出应为 Composer version 2.7.x 或更高;若仍是 1.x,说明你调用的不是新装的二进制
  • 运行 which composer,看路径是否和 --install-dir 一致;多个 Composer 共存时(如 Homebrew + 手动安装),容易调错
  • 运行 hash -d composer(bash/zsh)或重启终端,否则 shell 可能缓存旧路径,导致 composer --versionwhich composer 显示不一致

跨大版本(如从 v1 升 v2,或未来 v2 升 v3)后,首次运行 composer install 可能报 The lock file does not contain require-dev information —— 这是因为 v3 移除了 content-hash 字段,需删掉 composer.lock 重建。但这是后续问题,先确保你用的是正确的、校验过的二进制。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

161

2023.12.25

require的用法
require的用法

require的用法有引入模块、导入类或方法、执行特定任务。想了解更多require的相关内容,可以阅读本专题下面的文章。

509

2023.11.27

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

454

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

183

2023.10.30

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

454

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

183

2023.10.30

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

280

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

516

2024.04.08

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.5万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.6万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 7.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号