登录
首页 >  文章 >  linux

Linux下安装Composer的完整教程

时间:2026-03-15 20:36:42 184浏览 收藏

本文详细讲解了在Linux系统中正确安装Composer的完整流程,强调摒弃过时且不可靠的系统包管理器安装方式,转而采用官方校验脚本进行安全、可控的安装;涵盖全局安装与无sudo权限下的用户级安装两种场景,明确指出SHA384校验的必要性、PATH配置的关键细节,以及常见报错(如zip/openssl扩展未启用)的精准排查与修复方法,帮助开发者避开版本滞后、执行失败、依赖解压异常等典型陷阱,确保Composer在PHP 8.2+及现代项目中稳定高效运行。

linux怎么安装composer_linux配置php工具【步骤】

直接用包管理器装 Composer 通常不推荐

Linux 发行版仓库里的 composer 版本普遍滞后,常卡在 2.2.x 或更老,而 PHP 8.2+ 项目依赖的新特性(比如插件签名验证、composer install --no-plugins 行为变更)在旧版里要么报错要么静默失效。Debian/Ubuntu 的 apt install composer 装的是系统级全局二进制,更新还得等上游打包,不现实。

实操建议:

  • 删掉系统包:运行 sudo apt remove composer(Ubuntu/Debian)或 sudo dnf remove composer(Fedora),避免 PATH 冲突
  • 改用官方安装脚本:它生成的是用户可控制的单文件二进制,版本明确、路径清晰、升级方便
  • 别用 curl -sS https://getcomposer.org/installer | php 这种管道写法——网络中断或校验失败时会留下半截 composer.phar,后续执行直接报 PHP Parse error

用官方脚本安装并设为全局命令

核心是两步:下载校验 + 移动到 PATH 目录。官方脚本自带 SHA384 校验,必须保留,否则可能载入被篡改的安装器。

实操步骤:

  • 执行:php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');"
  • 校验:php -r "if (hash_file('sha384', 'composer-setup.php') === 'e0012edf3e89b657635bb18028ff4d631e503e6d1719a68a573b9c43762368305b7d7b5305094268a192751d42723218441d5' || hash_file('sha384', 'composer-setup.php') === '55ce33d7678c5a611085589f1f3ddf8b3c52d662cd01d4ba75c0ee0459970c2200a51f492d557530c46b93417144677c8127') { 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
  • 验证:composer --version 应输出类似 Composer version 2.7.7

非 root 用户怎么装(比如共享服务器无 sudo 权限)

不能往 /usr/local/bin 写?那就放自己家目录,再把路径加进 $PATH。关键不是“能不能装”,而是“shell 启动时能不能找到它”。

实操要点:

  • 装到本地:php composer-setup.php --install-dir=$HOME/bin --filename=composer(先确保 $HOME/bin 目录存在)
  • 追加 PATH:在 $HOME/.bashrc$HOME/.zshrc 末尾加一行 export PATH="$HOME/bin:$PATH"
  • 重载配置:source ~/.bashrc(或 source ~/.zshrc),然后 which composer 应返回 /home/用户名/bin/composer
  • 别漏掉:如果用的是 tmux/screen 或 cron,它们可能不读 .bashrc,得检查 shell 启动方式,必要时在脚本开头显式 source ~/.bashrc

装完 composer 但运行时报 “PHP extension zip not loaded”

这不是 Composer 自身问题,而是它依赖的 PHP 扩展没开。Composer 解压包、处理 ZIP 归档、校验 Phar 必须用到 zipopenssl 扩展,缺一不可。

排查和修复:

  • 先确认:php -m | grep -E '^(zip|openssl)$' —— 两个都得有输出
  • Ubuntu/Debian 缺 zip:sudo apt install php-zip,然后重启 PHP-FPM 或 Apache(sudo systemctl restart php8.2-fpm
  • CentOS/RHEL/Fedora:sudo dnf install php-pecl-zip(注意不是 php-zip
  • 自编译 PHP?确保 configure 时加了 --with-zip,且 extension=zip.sophp.ini 里没被注释
  • 别只改 CLI 的 php.ini:Web 环境跑 composer install(比如部署脚本)时,用的是 Web SAPI 的配置,得查 phpinfo() 输出的 “Loaded Configuration File”

扩展没加载全,composer create-project 可能卡在 “Installing dependencies” 不动,或者解压 vendor 时直接报 ZipArchive::extractTo(): Invalid or uninitialized Zip object —— 这时候别怀疑网络,先看扩展。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Linux下安装Composer的完整教程》文章吧,也可关注golang学习网公众号了解相关技术文章。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>