PHP项目404错误解决方法大全
时间:2026-01-29 13:00:46 409浏览 收藏
小伙伴们对文章编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《PHP项目404错误解决方法【要点】》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!
PHP项目上线404主因是Web服务器未正确转发请求,需依次排查:Apache检查mod_rewrite、.htaccess、AllowOverride;Nginx核对location、fastcgi_pass、root及try_files;再查PHP-FPM状态、权限与SELinux;最后确认框架入口路径与大小写。

PHP项目上线后出现404,绝大多数情况不是代码写错了,而是Web服务器没把请求正确转发给PHP处理——先查服务器配置,再看路由和重写规则。
Apache下index.php不生效或伪静态失效
常见现象:访问 https://example.com/ 返回404,但直接访问 https://example.com/index.php 能正常打开;或者 Laravel、ThinkPHP 的路由(如 /user/profile)全部 404。
- 确认
.htaccess文件已上传且未被忽略(尤其是 Git 忽略了隐藏文件) - 检查 Apache 是否启用了
mod_rewrite:a2enmod rewrite
并重启服务 - 确保虚拟主机配置中
AllowOverride设置为All(不能是None):<Directory /var/www/html><br> AllowOverride All<br> Require all granted<br></Directory>
- 若用的是 Apache 2.4+,
Order allow,deny类旧语法已失效,必须改用Require all granted
Nginx下PHP文件返回404而非执行
典型错误:Nginx 把 /index.php 当作静态文件找,找不到就 404;根本没交给 php-fpm 处理。
- 确认
location ~ \.php$块存在且位置正确(通常在 server 块内),且包含fastcgi_pass指向正确的php-fpmsocket 或端口 - 关键参数不能漏:
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;—— 缺失会导致 PHP 找不到脚本路径 - 检查
root指令是否指向项目真实根目录(比如/var/www/myapp/public),而不是上层目录 - 伪静态需显式配置:Laravel 常用的
try_files $uri $uri/ /index.php?$query_string;必须写在location /块里
PHP-FPM或权限导致的“找不到文件”假404
现象看似 404,实则是 Nginx/Apache 收到 PHP-FPM 返回的空响应或 403,最终回退成 404;日志里可能看到 connect() failed (111: Connection refused) 或 Permission denied。
- 确认
php-fpm服务正在运行:systemctl status php*-fpm
(版本号要匹配,如php8.1-fpm) - 检查
listen配置(/etc/php/*/fpm/pool.d/www.conf)是否与 Nginx 中的fastcgi_pass一致(127.0.0.1:9000还是/run/php/php8.1-fpm.sock) - 确认 Web 服务器用户(如
www-data或nginx)对项目目录有读+执行权限:chmod -R 755 /var/www/myapp
,尤其public/和storage/目录 - SELinux 启用时会拦截 socket 访问,临时验证可运行:
setenforce 0
(仅调试,勿长期关闭)
框架路由/入口文件路径配置错误
即使 Web 服务器配置全对,框架自身也可能因路径错乱返回 404,尤其部署时修改过目录结构。
- Laravel:确认
public/index.php是唯一入口,且APP_URL和ASSET_URL在.env中指向正确域名(不要带/public) - ThinkPHP:检查
public/index.php中的define('BASE_PATH', __DIR__ . '/../');是否准确;URL 模式开启需对应 Web 服务器重写规则 - 自定义入口:如果把
index.php移到了子目录(如/blog/index.php),则 Web 服务器的root或Alias必须同步调整,否则$document_root解析错误 - 注意大小写:Linux 文件系统区分大小写,
Index.php≠index.php,上传工具自动改名可能导致 404
真正卡住的地方往往不在 PHP 代码里,而在 Web 服务器对 URI 的解析链条上:从域名 → 虚拟主机 → root 路径 → 重写规则 → 入口文件 → 路由分发。每一步都得对得上,漏一个环节,就 404。
到这里,我们也就讲完了《PHP项目404错误解决方法大全》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
498 收藏
-
439 收藏
-
133 收藏
-
228 收藏
-
204 收藏
-
188 收藏
-
317 收藏
-
459 收藏
-
333 收藏
-
125 收藏
-
433 收藏
-
104 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习