当前位置: 首页
编程语言
Composer如何在Ubuntu上安装_Composer Ubuntu安装教程【推荐】

Composer如何在Ubuntu上安装_Composer Ubuntu安装教程【推荐】

热心网友 时间:2026-05-03
转载

必须用官方脚本安装Composer而非apt,因apt版版本陈旧(2.2.x)、不支持现代框架、self-update失效且无PATH配置;需校验SHA384并确保zip/phar/mbstring等PHP扩展启用。

Composer如何在Ubuntu上安装_Composer Ubuntu安装教程【推荐】

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

这里有个核心建议:千万别图省事用 apt install composer。这个命令装出来的,可以说是个“假全局”版本——版本号通常被锁死在 2.2.22 或更早,不仅无法满足现代框架对 ^2.5 的依赖约束,在 PHP 8.3 环境下甚至会直接报错。更麻烦的是,后续的 composer self-update 要么失败,要么会静默降级,让你陷入版本困境。

为什么 apt install composer 一定不能用

原因很简单,Ubuntu 官方软件源里的 php-composer 包并非由 Composer 官方团队维护,更新节奏严重滞后。截至 2026 年 4 月,即便是最新的 LTS 系统,默认提供的也普遍是 2.2.x 版本。这个版本存在几个硬伤,每一个都可能成为你后续开发的绊脚石:

  • 安装路径不可写:它被装在 /usr/share/php/composer/composer,这个目录通常没有写入权限,导致 self-update 命令永远卡住,无法升级。
  • 环境配置缺失:安装后不会自动加入系统的 $PATH 环境变量,甚至可能没有设置执行权限。结果就是,装完直接在终端输入 composer --version,很可能会得到一个 command not found 的报错。
  • 与现代框架不兼容:像 Lara vel 11+、Symfony 7+ 这类现代框架,已经明确要求 Composer 2.5+ 版本,因为它们依赖新版在自动加载优化和插件加载逻辑上的改进。使用旧版,框架会直接拒绝执行 install 命令。

如何判断自己是否“中招”?很简单,在终端运行 composer --version。如果输出信息里包含 2.0.x2.2.x,那基本就可以判定你安装的是有问题的 apt 版本。

必须校验 SHA384 后再安装 composer.phar

跳过校验步骤看似省事,实则是在给自己的项目埋下严重的安全隐患。试想,如果下载过程被中间人劫持,那么后续所有依赖包的安装、自动加载文件的生成都将变得不可信。这里务必注意,校验用的签名必须来自官网(https://www.php.cn/link/50c8932f79e0369ac94e06e9c6bd86e5),而不是第三方镜像站提供的哈希值。

最稳妥的做法是,直接复制并执行下面这条包含了完整校验流程的命令:

EXPECTED_CHECKSUM="$(curl -sS https://www.php.cn/link/50c8932f79e0369ac94e06e9c6bd86e5)"
php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
ACTUAL_CHECKSUM="$(php -r "echo hash_file('sha384', 'composer-setup.php');")"
if [ "$EXPECTED_CHECKSUM" != "$ACTUAL_CHECKSUM" ]; then
  echo 'Integrity check failed' >&2; rm composer-setup.php; exit 1
fi
sudo php composer-setup.php --install-dir=/usr/local/bin --filename=composer
rm composer-setup.php

安装完成后,用 composer --version 验证一下,如果输出类似 Composer version 2.7.7 这样的信息,就说明安装成功了。

PHP 扩展缺失会导致 composer install 直接崩

这里有个常见的认知误区:composer --version 能成功运行,并不代表 Composer 就能正常工作了。真正到了执行 composer install 这种重体力活的时候,全靠底层的 PHP 扩展支撑。缺少任何一个关键扩展,进程都可能直接崩溃:

  • zip:用于解压 vendor 里的依赖包,缺少会报 Class 'ZipArchive' not found
  • phar:用于构建和读取 PHAR 文件,缺少会报 PharData not found
  • mbstring, xml, json, curl:这些扩展负责解析 composer.json、处理远程仓库元数据、生成自动加载的类映射文件,缺一不可。

如何确认这些扩展是否已启用?运行命令 php -m | grep -E "zip|phar|mbstring|xml|json|curl" 查看。如果发现有缺失,需要根据你的 PHP 主版本进行安装。例如,在 PHP 8.3 环境下,需要执行 sudo apt install php8.3-zip php8.3-phar ...(安装前先用 php -v 确认版本)。修改配置后通常不需要重启服务,但要确保命令行 PHP 使用的配置文件(通过 php --ini 查看路径)里,对应的 extension= 行没有被注释掉。

composer global require 的命令找不到?PATH 没配对

运行了 composer global require lara vel/installer 之后,却在终端输入 lara vel 时得到 command not found 的提示?这通常不是 Composer 本身的问题,而是你的系统 Shell 找不到全局安装的二进制文件所在目录。

  • Composer 默认会把通过 global require 安装的工具,放在 ~/.composer/vendor/bin/ 目录下,而这个路径并不在 Ubuntu 默认的 $PATH 环境变量里。
  • 临时解决方案:在当前终端执行 export PATH="$HOME/.composer/vendor/bin:$PATH"
  • 永久解决方案:将上面这行命令添加到你的 Shell 配置文件里,比如 ~/.bashrc~/.zshrc(取决于你使用的 Shell)。
  • 一个关键提醒:执行 composer global 相关命令时,切记不要在前面加 sudo。否则,工具会被安装到 /root/.composer/vendor/bin/,普通用户自然找不到。

验证是否配置成功:可以执行 echo $PATH 查看输出是否包含上述路径;再运行 which lara vel,应该会返回该命令的完整安装路径。

话说回来,整个安装过程中,最容易被忽略的其实就是文件完整性校验和 PHP 扩展的完备性这两步。很多人看到 composer --version 成功输出就以为万事大吉,结果第一次执行真正的 install 命令时就卡死或报错,回头排查又要绕一大圈,得不偿失。

来源:https://www.php.cn/faq/2321051.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
VSCode如何配置搜索排除目录_VSCode搜索排除目录配置总结

VSCode如何配置搜索排除目录_VSCode搜索排除目录配置总结

VSCode如何配置搜索排除目录:一份避坑指南 如果你在VSCode里搜索代码,结果总被node_modules这类目录干扰,那大概率是配置没弄对。这里有个核心结论,务必记牢:想让全局搜索(Ctrl+Shift+F)真正跳过某些目录,必须使用search exclude设置,并把它写入setting

时间:2026-05-03 11:49
怎么在Notepad++中实现选中文本后自动搜索

怎么在Notepad++中实现选中文本后自动搜索

怎么在Notepad++中实现选中文本后自动搜索 在Notepad++里,选中一段代码或文字然后按下Ctrl+F,本该是件顺理成章的事。但很多时候,你会发现这个组合键要么没反应,要么弹出了对话框却什么都不做。这背后其实是一系列小细节在“作祟”,从搜索模式到快捷键绑定,再到高亮功能的正确打开方式。咱们

时间:2026-05-03 11:49
VSCode禁止自动更新_保持稳定版本的配置修改方法

VSCode禁止自动更新_保持稳定版本的配置修改方法

VSCode禁用自动更新:从配置到防火墙的完整锁定指南 你是否也遇到过这样的场景?在某个关键的生产环境调试,或者正专注于一个复杂的CI CD流水线本地测试,VSCode突然弹出一个更新提示。对于追求稳定性的开发者来说,这可不是点一下“跳过”就能了事的。我们需要的是一个彻底的解决方案——从配置层面,直

时间:2026-05-03 11:49
VSCode Jupyter Notebook_数据科学开发与可视化配置

VSCode Jupyter Notebook_数据科学开发与可视化配置

VSCode中Jupyter Notebook无法运行,90%因内核未注册或选错环境;需在目标环境执行python -m ipykernel install注册,重启VSCode后手动选择右上角内核,而非依赖底部Python解释器选择。 遇到VSCode里的Jupyter Notebook跑不起来,

时间:2026-05-03 11:48
Notepad++怎么解决右键菜单里没有Notepad++选项

Notepad++怎么解决右键菜单里没有Notepad++选项

Notepad++右键菜单消失?主因是NppShell64 dll未被Win11正确加载 遇到Notepad++右键菜单不翼而飞,先别急着折腾注册表或者怀疑自己路径写错了。问题的根源,往往在于Windows 11的Shell扩展加载机制和Notepad++的集成方式之间“断了线”——核心文件NppS

时间:2026-05-03 11:48
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程