0

0

解决 PHP 扩展缺失错误:以 json 和 mbstring 为例

花韻仙語

花韻仙語

发布时间:2025-10-27 10:51:10

|

814人浏览过

|

来源于php中文网

原创

解决 PHP 扩展缺失错误:以 json 和 mbstring 为例

php 脚本提示 json 或 mbstring 等扩展缺失,即使已在控制面板中启用,这通常是配置未加载或服务未重启所致。本教程将指导您通过 phpinfo() 验证扩展状态,并确保正确启用后,重启相关服务以彻底解决此问题。

在 PHP 应用部署过程中,开发者经常会遇到“请求的 PHP 扩展缺失”的错误提示,例如 ERROR: The requested PHP extension json is missing from your system. 或 ERROR: The requested PHP extension mbstring is missing from your system.。尽管用户可能已经在主机控制面板(如 CPanel)中明确启用了这些扩展,但错误依然存在。这通常不是因为扩展未安装,而是因为 PHP 运行环境未能正确加载这些已启用的配置,或者相关的服务在配置更改后未重启。本教程将详细介绍如何诊断和解决这类问题。

一、理解问题根源

PHP 扩展的启用通常涉及修改 php.ini 配置文件。当您在 CPanel 或其他控制面板中启用扩展时,实际上是系统在后台修改了相应的 php.ini 文件。然而,PHP 解释器(无论是作为 Apache/Nginx 模块运行,还是通过 PHP-FPM 独立运行)并不会立即感知到这些配置更改。它需要重新加载配置,这通常通过重启相关的服务来实现。如果服务未重启,PHP 将继续使用旧的配置,从而报告扩展缺失。

二、验证扩展状态:使用 phpinfo()

解决此类问题的第一步是精确诊断 PHP 当前运行环境的实际状态。phpinfo() 函数是 PHP 提供的一个强大工具,可以显示 PHP 的所有配置信息、已加载的扩展、服务器环境等。

  1. 创建 phpinfo.php 文件: 在您的网站根目录或任何可以通过浏览器访问的目录下,创建一个名为 phpinfo.php 的文件,并添加以下内容:

  2. 通过浏览器访问: 在您的浏览器中访问 http://您的域名/phpinfo.php。

  3. 检查扩展信息: 在 phpinfo() 的输出页面中,仔细查找 json 和 mbstring 扩展的相关信息。

    • 查找 json 扩展: 通常会有一个名为 "json" 的独立模块部分。如果该部分存在并显示 "json support => enabled",则表示 json 扩展已成功加载。
    • 查找 mbstring 扩展: 同样,查找名为 "mbstring" 的模块部分。如果存在并显示 "mbstring support => enabled" 或类似的激活状态,则表示 mbstring 扩展已加载。
    • 注意 Loaded Configuration File: 在 phpinfo() 输出的顶部,会显示 Loaded Configuration File(已加载的配置文件)的路径。请务必记下这个路径,因为它指示了当前 PHP 实例正在使用的 php.ini 文件。

通过 phpinfo() 的输出,您可以明确判断是扩展确实未加载,还是仅仅是您的应用程序未能正确检测到。如果 phpinfo() 显示扩展已加载,但应用程序仍报错,则可能需要检查应用程序自身的配置或缓存。如果 phpinfo() 也显示扩展缺失,那么问题在于 PHP 运行环境本身。

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

三、确保扩展已正确启用

如果 phpinfo() 确认扩展缺失,您需要重新检查其启用状态。

  1. CPanel PHP Selector: 如果您使用的是 CPanel,请再次访问 CPanel 的 "Select PHP Version" 或 "PHP Selector" 工具。确保 json 和 mbstring 扩展旁边的复选框已选中。有时,即使选中,也可能需要重新保存或应用更改。

  2. 手动编辑 php.ini: 在某些情况下,您可能需要直接编辑 php.ini 文件。根据 phpinfo() 中显示的 Loaded Configuration File 路径,找到正确的 php.ini 文件。打开该文件,并确保以下行存在且未被注释(即行首没有 ; 符号):

    extension=json.so
    extension=mbstring.so

    请注意,.so 是 Linux 系统上的扩展名,Windows 系统上通常是 .dll。如果您不确定扩展文件的具体名称或路径,可以查看 php.ini 中 extension_dir 的设置,并检查该目录下是否存在 json.so 和 mbstring.so 文件。

四、重启相关服务

这是解决此类问题的关键一步,也是最常被忽略的环节。无论您是通过控制面板还是手动编辑 php.ini 启用了扩展,PHP 运行环境都需要重新加载其配置才能生效。

您需要重启的服务取决于您的服务器配置:

AdsGo AI
AdsGo AI

全自动 AI 广告专家,助您在数分钟内完成广告搭建、优化及扩量

下载
  1. PHP-FPM 服务: 如果您的 PHP 是通过 PHP-FPM 运行的(例如与 Nginx 或 Apache 结合使用),则需要重启 PHP-FPM 服务。

    • CPanel 用户: CPanel 通常提供一个界面来管理 PHP-FPM 服务,您可以在其中找到重启选项。

    • SSH 用户(Linux): 通过 SSH 连接到您的服务器,并执行以下命令(具体命令可能因 Linux 发行版和 PHP 版本而异):

      sudo systemctl restart php-fpm
      # 或者针对特定版本
      sudo systemctl restart php7.4-fpm
      sudo systemctl restart php8.0-fpm
      # 对于使用 init.d 的系统
      sudo /etc/init.d/php-fpm restart
  2. Web 服务器服务(Apache/Nginx): 如果 PHP 是作为 Apache 模块(mod_php)运行的,或者即使使用 PHP-FPM,重启 Web 服务器有时也能确保所有相关进程都重新加载配置。

    • CPanel 用户: CPanel 通常提供重启 Apache 或 Nginx 的选项。

    • SSH 用户(Linux):

      # 对于 Apache
      sudo systemctl restart httpd
      # 或者
      sudo systemctl restart apache2
      
      # 对于 Nginx
      sudo systemctl restart nginx

重要提示: 在重启服务之前,请确保保存所有未完成的工作,因为重启会导致短暂的服务中断。

五、验证解决方案

在重启相关服务后,再次通过浏览器访问您之前创建的 phpinfo.php 文件。确认 json 和 mbstring 扩展现在是否已显示为已启用。如果 phpinfo() 显示正常,那么您的应用程序应该也能正确识别这些扩展并正常运行。

六、注意事项与总结

  • 多 PHP 版本环境: 如果您的服务器上安装了多个 PHP 版本,请确保您正在为您的应用程序所使用的特定 PHP 版本启用和配置扩展。phpinfo() 将明确显示当前正在使用的 PHP 版本和其对应的 php.ini 文件。
  • 错误日志: 如果问题依然存在,请检查 Web 服务器(Apache/Nginx)的错误日志和 PHP-FPM 的错误日志。这些日志文件通常会提供更详细的错误信息,帮助您进一步诊断问题。
  • 权限问题: 确保 PHP 进程对 php.ini 文件和扩展目录有读取权限。

通过遵循上述步骤,您应该能够有效诊断并解决 PHP 扩展缺失的问题。核心在于:使用 phpinfo() 准确了解当前 PHP 运行环境,确保 php.ini 配置正确,并在更改后及时重启相关服务。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2860

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1703

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1560

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

1078

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1525

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1277

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1629

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1309

2023.11.13

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

41

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9.3万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 10.7万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号