PHP版本升级后404由Web服务器(Apache/Nginx)未正确转发请求至对应PHP处理器导致,需检查模块加载、php-fpm配置、权限、.htaccess规则及错误日志。

PHP版本升级后出现404,先查Apache或Nginx是否转发到正确PHP处理器
PHP本身不返回404,真正返回404的是Web服务器(如Apache/Nginx)——它找不到能处理 .php 文件的后端,或根本没把请求交给PHP执行。常见于从PHP 7.x升到8.x后,系统仍用旧的libphp.so模块,或php-fpm服务未监听对应socket/port。
- 检查Apache是否加载了匹配当前PHP版本的
mod_php:运行apache2ctl -M | grep php(Debian/Ubuntu)或httpd -M | grep php(RHEL/CentOS),确认输出含php8_module而非php7_module - 若用
php-fpm,确认www.conf中listen路径或端口与vhost配置一致,例如Nginx里fastcgi_pass unix:/run/php/php8.2-fpm.sock;对应的是/etc/php/8.2/fpm/pool.d/www.conf - 重启服务顺序不能错:先
systemctl restart php8.2-fpm,再systemctl restart apache2(或nginx)
PHP-FPM池配置错位导致404(尤其多版本共存时)
多个PHP版本共存时,容易把php-fpm池名、socket路径、用户组写混,Nginx/Apache按配置去找却连不上,最终降级为静态文件处理——而.php文件不存在静态副本,就返回404。
- 每个PHP版本的FPM服务必须独立启动:比如
php8.1-fpm和php8.2-fpm不能共用同一systemd单元;确认systemctl list-units | grep fpm列出的是你实际启用的版本 - 检查
www.conf里的user/group是否与Web服务器运行用户一致(如www-data),否则socket文件权限拒绝访问,Nginx日志会报connect() to unix:/run/php/php8.2-fpm.sock failed (13: Permission denied) - 临时验证:用
curl --unix-socket /run/php/php8.2-fpm.sock http://localhost/status看能否连通FPM状态页(需开启pm.status_path)
Apache .htaccess 或 Directory 指令丢失PHP处理规则
PHP版本切换常伴随重装或配置重置,AllowOverride被设为None,或AddHandler/SetHandler未适配新模块名,导致.php文件被当作纯文本返回(404是因找不到同名.html/.txt)。
- 在站点
块中确认有类似配置:
注意:PHP 8.x Apache模块名已从SetHandler application/x-httpd-php application/x-httpd-php7改为application/x-httpd-php(无版本号) - 如果启用了
mod_rewrite且项目依赖.htaccess(如WordPress、Laravel),确保AllowOverride All已生效,否则RewriteRule不触发,路由层无法接管,直接404 - 禁用所有
.htaccess测试:把AllowOverride设为None,并在主配置里显式写好DirectoryIndex index.php和FilesMatch规则,排除覆盖干扰
PHP 8.0+ 移除了mysql_*()扩展但错误日志被静默
这不是直接导致404的原因,但极易误导排查方向:当脚本因调用废弃函数崩溃,而错误报告被display_errors=Off或log_errors=Off掩盖,Web服务器收不到任何响应体,可能超时或回落到404(尤其Nginx配了fastcgi_intercept_errors on时)。
立即学习“PHP免费学习笔记(深入)”;
- 检查
php.ini中error_log路径是否可写,log_errors = On,error_reporting = E_ALL - 临时在入口文件顶部加:
error_reporting(E_ALL); ini_set('display_errors', '1'); ini_set('log_errors', '1');看是否爆出Fatal error: Uncaught Error: Call to undefined function mysql_connect() - PHP 7.4起已彻底移除
mysql_*,8.0+仅保留mysqli和PDO;确认代码已替换,或通过php -m | grep mysql验证扩展是否加载
最常被忽略的是Web服务器日志——不是PHP错误日志,而是access.log里看请求是否到达,error.log里看有没有connect() to ... failed或File does not exist。404从来不是PHP版本问题,只是版本切换过程中,某一层的衔接断开了。











