XAMPP中Apache无法加载php模块解决方法
时间:2026-05-05 14:00:46 369浏览 收藏
有志者,事竟成!如果你在学习文章,那么本文《XAMPP中Apache无法加载php模块解决方法》,就很适合你!文章讲解的知识点主要包括,若是你对本文感兴趣,或者是想搞懂其中某个知识点,就请你继续往下看吧~
本质是XAMPP未正确引入httpd-xampp.conf配置文件,导致PHP处理器未启用;需确认httpd.conf中Include "conf/extra/httpd-xampp.conf"未被注释,并检查该文件内SetHandler application/x-httpd-php是否生效,同时排除端口占用及PHP配置路径错误。

XAMPP 中 Apache 无法加载 PHP 模块,本质不是“模块没装”,而是 httpd.conf 里没正确关联已内置的 PHP 处理器——XAMPP 自带 PHP,但默认配置可能被改过、或因多版本冲突失效。
检查 XAMPP 的 php_module 是否实际启用
XAMPP 的 Apache 并不靠 LoadModule php_module 手动加载 so/dll,而是通过 Include "conf/extra/httpd-xampp.conf" 引入专用配置。如果这行被注释或删了,PHP 就彻底失联。
- 打开
C:\xampp\apache\conf\httpd.conf(Windows)或/opt/lampp/etc/httpd.conf(Linux/macOS) - 搜索
httpd-xampp.conf,确认该行未被注释(即前面没有#) - 若找不到这行,说明配置被重置过,需手动加回:
Include "conf/extra/httpd-xampp.conf" - 保存后运行
xampp-control.exe→ 点击 Apache 的 “Stop” 再 “Start”,不要只点 Restart
验证 httpd-xampp.conf 是否真在处理 .php 文件
即使 httpd-xampp.conf 被引入,它内部仍需明确声明 PHP 处理器。XAMPP 6.0+ 默认用 SetHandler application/x-httpd-php,但旧版或手动改过的内容可能残留 AddType 或错误的 SetHandler。
- 打开
C:\xampp\apache\conf\extra\httpd-xampp.conf - 查找包含
.php的或AddHandler区块 - 确认存在类似以下内容(注意路径和 handler 名称必须匹配当前 PHP 版本):
<FilesMatch "\.php$"> SetHandler application/x-httpd-php </FilesMatch> - 如果看到
AddType application/x-httpd-php .php,保留它也行,但优先以SetHandler为准;两者共存不冲突,但顺序错可能导致覆盖
端口占用或服务冲突导致模块“假失败”
Apache 启动日志显示 Cannot load php_module,有时根本不是模块问题,而是 Apache 根本没起来——比如 80/443 端口被 Skype、IIS、甚至另一个 XAMPP 实例占着,导致 httpd 进程异常退出,后续模块加载自然失败。
- 启动前先执行
netstat -ano | findstr :80(Windows)或lsof -i :80(macOS/Linux),看 PID 是谁 - 若 PID 对应非
httpd.exe或apache2,杀掉它:taskkill /PID 1234 /F(Windows)或kill -9 1234(其他系统) - 再试启动;如果仍失败,查
C:\xampp\apache\logs\error.log,重点看第一行报错,不是最后几行 - 常见干扰项:Windows 自带的 IIS(
sc query w3svc查状态)、Docker Desktop(默认占 80/443)、甚至 Zoom(旧版会抢 8080)
多 PHP 版本共存时的路径错位
XAMPP 控制面板右下角显示的 PHP 版本(如 8.2.12),和你命令行里 php -v 输出的版本不一致,说明系统 PATH 指向了外部 PHP,而 Apache 仍用 XAMPP 自带的。这时 php.ini 加载路径容易混乱,扩展(如 extension=openssl)可能因依赖库版本不匹配而静默失败,最终表现为 PHP 页面空白或 500 错误。
- 在浏览器访问
http://localhost/dashboard/phpinfo.php,看顶部 “Loaded Configuration File” 路径是否为C:\xampp\php\php.ini - 如果不是,说明 Apache 没读到 XAMPP 的配置,极可能是
httpd-xampp.conf里PHPINIDir设置错了,或被其他配置覆盖 - 临时验证:把
C:\xampp\php\php.ini复制一份到桌面,改名php.ini.bak,然后在httpd-xampp.conf里显式指定:PHPINIDir "C:/xampp/php"(注意正斜杠) - 重启 Apache,再刷
phpinfo.php确认路径是否修正
真正卡住的地方,往往不是模块加载本身,而是 Apache 启动失败后你只盯着“php_module”报错,却没看前一行的“no listening sockets”或“AH00526”。先让 Apache 跑起来,PHP 模块才有机会被加载。
到这里,我们也就讲完了《XAMPP中Apache无法加载php模块解决方法》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于XAMPP的知识点!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
359 收藏
-
109 收藏
-
199 收藏
-
310 收藏
-
244 收藏
-
234 收藏
-
198 收藏
-
442 收藏
-
448 收藏
-
192 收藏
-
325 收藏
-
354 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习