Composer 不安装 PHP 扩展,仅校验其是否启用;需在 composer.json 中以 ext-xxx 格式声明平台依赖,如 "ext-json": "*",并在系统层面通过 apt、brew、Dockerfile 或 php.ini 启用对应扩展。

Composer 本身不安装或启用 PHP 扩展,但它能检查当前环境是否满足扩展依赖,并在不满足时明确报错。处理 ext-json 这类扩展依赖的关键在于正确声明、理解其作用,以及配合部署流程确保环境就绪。
PHP 扩展属于“平台依赖”(platform requirements),需在 composer.json 的 require 或 require-dev 中以 ext-xxx 格式声明:
"ext-json": "*" 表示需要任意版本的 json 扩展(PHP 7.2+ 默认内置,无需单独安装)"ext-mbstring": "^1.0" 可指定最低版本(但多数扩展无语义化版本号,用 * 更常见)config.platform.php 中锁定 PHP 版本,间接影响扩展可用性运行 composer install 或 composer update 时,Composer 会自动调用 extension_loaded('json') 类似逻辑检测已启用的扩展。如果缺失:
The requested PHP extension ext-json is missing from your system.
很多人误以为声明 ext-json 就能让 Composer 自动安装它——其实不能。PHP 扩展必须由系统或 PHP 环境本身提供:
立即学习“PHP免费学习笔记(深入)”;
sudo apt install php-json(Debian/Ubuntu)或 php74-php-json(CentOS/RHEL)brew install php@8.2(通常自带 json);若自编译 PHP,需确认 configure 时含 --enable-json
Dockerfile 中显式启用,例如 RUN docker-php-ext-enable json(前提是已存在)或 apk add php82-json(Alpine)php.ini 中是否取消了 ;extension=json 的注释如果你在高版本 PHP 开发,但目标服务器是旧版且缺少某些扩展,可通过 config.platform 强制 Composer 按低配环境解析依赖(避免装入不兼容的包):
"config": {
"platform": {
"php": "7.4.33",
"ext-json": "7.4.33",
"ext-mbstring": "7.4.33"
}
}注意:这不会跳过真实扩展检查,只是让 Composer 在依赖分析阶段“假装”这些扩展存在,适用于 CI 或跨环境开发场景。
基本上就这些。扩展依赖不是 Composer 能解决的问题,而是它帮你守住的一道门——门后的事,得靠运维、Dockerfile 或 php.ini 来完成。
以上就是如何在 Composer 中处理 PHP 扩展(extensions)的依赖,如 ext-json?的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号