答案是升级系统ICU库或PHP intl扩展以满足版本要求。当Composer报错缺少lib-icu时,说明PHP的intl扩展依赖的底层ICU库版本过低;可通过php -r "echo INTL_ICU_VERSION;"检查当前版本,若低于要求(如60.1),需升级系统ICU并重装intl扩展;Ubuntu/Debian用户使用apt安装libicu-dev并重装php-intl,CentOS/RHEL/Fedora用户使用dnf安装libicu-devel并重装php-intl;若系统包版本太旧,可考虑手动编译ICU或改用Docker镜像(如php:8.2-fpm配合安装libicu-dev并启用intl扩展);临时方案包括降级symfony/intl到兼容旧ICU的版本或引入symfony/polyfill-intl-*组件替代部分功能;修复后再次检查ICU版本并运行composer install验证是否解决。

当你在使用 Composer 安装或更新 PHP 项目依赖时,遇到类似 "Your system does not meet the requirements to run this application. requires lib-icu youjiankuohaophpcn= 60.1" 的提示,说明当前 PHP 环境缺少满足版本要求的 ICU(International Components for Unicode) 库支持。这通常影响到 symfony/intl、symfony/polyfill 或其他需要国际化功能的组件。
Composer 报错中的 lib-icu 指的是系统级 ICU 库版本,而非 PHP 扩展本身。PHP 的 intl 扩展依赖于这个底层库。即使你已启用 intl 扩展,若其编译时链接的 ICU 版本过低,依然会报错。
常见错误信息示例:
Package icu4c not found (required by symfony/intl)requires ext-intl * -> the ' intl' extension is missing or has an outdated ICU version.requires lib-icu >= 60.1运行以下命令查看 PHP 中 ICU 的实际版本:
php -r "echo INTL_ICU_VERSION;\n";
再查看所需最低版本(比如报错中提到 >=60.1),如果输出是 50.1、55.1 等低于要求的版本,就需要升级。
也可以通过:
php -m | grep intl
确认 intl 扩展是否已启用。
根据你的操作系统和环境选择合适的方式升级 ICU 和 intl 扩展。
方案一:升级系统 ICU 并重新编译 PHP intl 扩展(推荐)
sudo apt update sudo apt install libicu-dev # 然后重新安装 php-intl 扩展 sudo apt remove php-intl sudo apt install php-intl
sudo dnf install libicu-devel sudo dnf reinstall php-intl
方案二:使用 Docker 或更高版本的 PHP 环境
本地环境升级困难时,建议改用 Docker 镜像,例如:
FROM php:8.2-fpm
RUN apt-get update && apt-get install -y libicu-dev \
&& docker-php-ext-install intlDocker 镜像通常自带较新的 ICU 版本,可避免此类问题。
方案三:降级依赖(临时规避)
如果你无法升级系统 ICU,可尝试降低对 symfony/intl 或相关包的版本要求,例如使用兼容旧 ICU 的版本:
"require": {
"symfony/intl": "v4.4.0"
}但不推荐长期使用,可能带来安全或功能缺失问题。
方案四:使用 polyfill 替代
很多情况下,并不需要完整的 ext-intl 功能。Symfony 提供了 symfony/polyfill-intl-*` 组件来模拟部分行为。
在 composer.json 中加入:
"require": {
"symfony/polyfill-intl-normalizer": "*",
"symfony/polyfill-intl-grapheme": "*",
"symfony/polyfill-intl-idn": "*"
}某些组件在检测不到 intl 时会自动退回到 polyfill,但仍需看具体库是否支持。
修复后再次运行:
php -r "echo INTL_ICU_VERSION;\n";
确保输出的版本 ≥ 要求值(如 60.1)。然后执行:
composer install
应不再出现 ICU 相关错误。
基本上就这些。关键是让 PHP 的 intl 扩展链接到足够新版本的 ICU 库。开发环境下推荐使用 Docker 或现代化发行版系统以减少此类依赖困扰。
以上就是composer提示“requires lib-icu >= ...”的依赖问题如何解决的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号