商城首页欢迎来到中国正版软件门户

您的位置:首页 >Composer提示phar扩展未开启_在php.ini中激活组件【基础环境】

Composer提示phar扩展未开启_在php.ini中激活组件【基础环境】

  发布于2026-04-25 阅读(0)

扫一扫,手机访问

Composer 报错 “phar extension is not enabled” 的完整解决指南

Composer提示phar扩展未开启_在php.ini中激活组件【基础环境】

遇到 Composer 提示 “phar extension is not enabled”,先别急着重装或怀疑权限。这个错误的根源很明确:你当前使用的 PHP 环境,在启动时没有加载一个名为 phar 的核心扩展。简单说,这不是 Composer 的问题,而是 PHP 配置层面缺少了一个关键组件。

Composer 报错 “phar extension is not enabled” 怎么办

直接说结论:Composer 的运行机制深度依赖 phar 扩展。当 PHP 启动时找不到这个扩展,Composer 就会立刻“罢工”并抛出这个错误。所以,解决问题的方向不是折腾 Composer 本身,而是去修复 PHP 的配置。

确认当前 PHP 是否真没启用 phar 扩展

动手修改配置之前,验证环节不能少。打开你的终端或命令行,执行下面这条命令:

php -m | grep phar

如果命令行一片寂静,没有任何输出,那就证实了 phar 扩展确实未被加载。但如果这里明明显示了 phar,Composer 却还在报错,那就要警惕了——很可能你的系统里存在多个 PHP 版本。Composer 可能调用了另一个没有启用 phar 的 PHP。这时候,需要对比一下 which phpcomposer --version 信息里隐含的 PHP 路径是否一致。

此外,还有几个关键信息需要确认:

  • 使用 php --ini 命令,查看当前 PHP 命令行接口(CLI)实际生效的 php.ini 配置文件路径。
  • 运行 php -v,确认 CLI 使用的具体 PHP 版本。
  • 对于 Linux 用户,特别是使用 Ubuntu 等发行版时要注意,扩展配置可能被拆分到了 /etc/php/X.X/cli/conf.d/ 这样的独立目录中。你需要检查该目录下是否存在类似 20-phar.ini 的配置文件,并确认它没有被注释或删除。

在 php.ini 中启用 phar 扩展的实操步骤

其实,phar 扩展自 PHP 5.3 起就已经是核心的一部分,默认在编译时包含。问题往往出在部分发行版(尤其是一些追求轻量的 Docker 镜像或最小化安装包)会选择默认禁用它。所以,我们的操作不是“安装”,而是“启用”。

立即学习“PHP免费学习笔记(深入)”;

  • 用文本编辑器打开上一步找到的 php.ini 文件。
  • 在文件中搜索 extension=phar 这一行。如果它前面有个分号(;extension=phar),那么这个扩展就被注释掉了。你的任务就是删掉这个分号。
  • 如果搜遍全文都找不到这一行,那就需要你手动在扩展列表区域添加一行:extension=phar。注意,现代 PHP 版本通常不需要加 .so(Linux)或 .dll(Windows)后缀,系统会自动识别。
  • 当然,如果你用的是 PHP 7.2 或更早的旧版本,有时可能需要明确写成 extension=phar.so 的形式。不过,优先尝试无后缀的写法。
  • 保存文件后,如果 Composer 错误出现在网页环境中,记得重启 Apache 或 Nginx 等 Web 服务。如果只是 CLI 环境,确保新启动的终端会话使用的是更新后的配置(可以用 php -c /path/to/your/php.ini -m | grep phar 来指定配置文件测试)。

Windows 下常见坑:dll 文件缺失或路径错误

Windows 环境下的用户,常常会在这里多绕几个弯。明明已经在 php.ini 里写上了 extension=php_phar.dll,却还是收到 “unable to load dynamic library” 的错误提示。问题可能出在以下几点:

  • 文件根本不存在:首先确认 php_phar.dll 这个文件是否真的位于 PHP 的扩展目录(ext)里。你可以通过 php -i | grep extension_dir 命令来查看扩展目录的具体路径。
  • 版本不匹配:检查你下载的 PHP 版本和正在使用的 php_phar.dll 文件是否来自同一个版本。混用不同版本的 DLL 文件是导致加载失败的常见原因。
  • 扩展名写错:Windows 下扩展的命名是固定的,必须是 php_phar.dll,写成 phar.dllphp-phar.dll 都无法识别。
  • 依赖项未启用phar 扩展的正常运行依赖于 mbstring 扩展。如果 php_mbstring.dll 没有被启用,phar 扩展可能会静默加载失败。因此,请一并检查 mbstring 是否已开启。

完成所有修改后,最终的验证步骤很简单:再次运行 php -m,在输出的模块列表中看到 phar 的身影,就说明成功了。此时再执行 composer --version,那个令人头疼的错误应该已经消失了。

最后提一个最容易被忽略的“陷阱”:在多 PHP 版本共存的环境下(例如,系统自带一个 PHP,你又通过包管理器或手动安装了另一个),命令行(CLI)、Web 服务器(如 Apache)甚至 IDE 内置终端所使用的 PHP 和 php.ini 可能各不相同。你修改了其中一个环境的配置,并不代表其他环境的问题也解决了。务必确保你修改的配置,正是出错的 Composer 所调用的那个 PHP 环境。

本文转载于:https://www.php.cn/faq/2317454.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注