phpEnv提示The PHP extension 'bcmath' is required 解决Laravel环境
时间:2026-05-05 17:31:01 448浏览 收藏
一分耕耘,一分收获!既然打开了这篇文章《phpEnv提示The PHP extension 'bcmath' is required 解决Laravel环境》,就坚持看下去吧!文中内容包含等等知识点...希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!
Laravel 启动报“bcmath 扩展缺失”是因框架在 LoadConfiguration.php 中硬性检测 bcadd() 等函数,用于金额计算、加密盐生成等关键操作;常见原因包括宝塔未启用该扩展、CLI 与 FPM 环境 php.ini 不一致、或 CentOS/AlmaLinux 下 yum 安装未匹配 PHP 版本。

为什么 Laravel 启动报 The PHP extension 'bcmath' is required?
这不是 Laravel 的 bug,而是它在 vendor/laravel/framework/src/Illuminate/Foundation/Bootstrap/LoadConfiguration.php 里做的硬性检查:只要检测到 bcadd()、bcmul() 等函数不可用,就直接抛出这个错误。Laravel 用 bcmath 做金额计算、加密盐生成、配置哈希等关键操作,不满足就拒绝启动。
常见诱因有三个:
• 宝塔面板里 PHP 版本已安装但 bcmath 没勾选启用;
• CLI(命令行)环境和 Web(FPM)环境用了不同的 php.ini,你改了 Web 的,但 php artisan 走的是 CLI 的;
• CentOS/AlmaLinux 上用 yum 安装时没指定 PHP 版本后缀,导致装错包或冲突。
确认是 CLI 还是 FPM 环境缺失 bcmath
必须分开查,因为它们可能完全独立:
- 查 CLI 是否可用:
php -m | grep bcmath或php -r "var_dump(extension_loaded('bcmath'));" - 查 FPM 是否可用:在网站根目录建
info.php,内容为,浏览器访问后搜索bcmath,同时记下 “Loaded Configuration File” 路径 - 对比两个环境的
php --ini输出,看是否指向不同php.ini
如果 CLI 有而 FPM 没有,说明你只改了 CLI 的配置;反之亦然。别只信 phpinfo() 页面——它只反映 Web 环境。
宝塔面板内快速启用 bcmath(推荐优先尝试)
适用于大多数宝塔用户,无需命令行,但要注意版本匹配:
- 登录宝塔 → 【软件商店】→ 找到你站点正在用的 PHP 版本(如
PHP 8.2),点【设置】 - 切换到【安装扩展】选项卡,找到
bcmath,点【安装】(不是【启用】) - 安装完成后,务必点右上角【重载配置】——这步漏掉,扩展不会加载进 FPM
- 再执行
php -m | grep bcmath,如果 CLI 还没出来,说明 CLI 用的是另一套配置,需手动补一行extension=bcmath.so到 CLI 对应的php.ini
注意:php -v 显示的版本号(如 8.2.15)和宝塔里显示的“PHP 8.2”要一致;若显示 8.3 却去点了 8.2 的扩展,肯定无效。
CentOS/AlmaLinux 下用 yum 安装 bcmath 的坑
直接 yum install php-bcmath 在多数现代系统上会失败,因为默认仓库不提供多版本共存支持:
- 先查当前 PHP 版本:
php -v,假设输出是PHP 8.1.27 - 查启用的 SCL 或 Remi 源:
yum repolist enabled | grep -E "(remi|epel)",没结果就先运行yum install epel-release && yum install https://rpms.remirepo.net/enterprise/remi-release-8.rpm - 启用对应 PHP 版本的模块:
dnf module enable php:remi-8.1(RHEL8+/AlmaLinux 8+)或yum-config-manager --enable remi-php81(CentOS 7) - 再装:
yum install php-bcmath(此时 remi 源会自动解析为php81-bcmath) - 重启服务:
systemctl restart php-fpm,并确认php -m | grep bcmath有输出
最容易被忽略的一点:Laravel 的 artisan 命令走的是 CLI,而网页请求走的是 FPM,二者可能由不同用户(如 root vs www)运行,权限或 open_basedir 限制也可能导致 .so 文件加载失败——所以看到 extension=bcmath.so 写对了,仍报错时,先 ls -l 看 bcmath.so 文件是否存在且可读。
好了,本文到此结束,带大家了解了《phpEnv提示The PHP extension 'bcmath' is required 解决Laravel环境》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
466 收藏
-
221 收藏
-
105 收藏
-
375 收藏
-
367 收藏
-
432 收藏
-
170 收藏
-
183 收藏
-
220 收藏
-
432 收藏
-
272 收藏
-
335 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习