路由404主因是路由文件未加载、请求方法不匹配、中间件拦截或URL路径偏差。需检查加载逻辑、HTTP方法、中间件顺序及部署配置,用命令行工具比对实际路由列表。
很多 PHP 框架(如 Laravel、ThinkPHP、CodeIgniter)的路由配置是独立文件,但框架启动时未必自动包含。漏写 require 或未在服务提供者中注册路由文件,会导致整个路由表为空,所有请求都 fallback 到 404。
routes/web.php 是否被 RouteServiceProvider 的 loadRoutesFrom() 或默认逻辑加载config/route.php 存在且返回数组,或 route/ 目录下有合法 PHP 文件并被 Route::import() 引入public/index.php)是否执行了类似 include 'app/routes.php';
HTTP 方法(GET/POST/PUT/DELETE)不一致是高频 404 原因。框架通常区分大小写且强制校验,get('/user') 不会响应 POST 请求,反之亦然。
Route::match(['get', 'post'], '/user', ...) 或 Route::any() 临时调试,但生产环境应明确方法Route::get() 和 Route::rule() 的 method 参数是否设为 '*' (允许任意方法)method="POST" 默认发 GET,容易误判有些中间件(如权限验证、跨域处理、URL 重写)会在路由匹配前抛出异常或直接 exit / die,导致请求根本没走到路由分发层,日志里却只显示 404。
app/Http/Kernel.php 中 $middleware 数组顺序,把日志类(如 LogRequests)放在最前,确认是否被某个中间件拦截storage/logs/laravel.log 是否有 InvalidArgumentException: Route [xxx] not defined 类错误 —— 这说明命名路由被引用但未声明,不是 404 而是逻辑错误Router::dispatch())前后加 var_dump('before route'); die; 快速定位中断点开发时容易忽略子目录部署、伪静态规则、或框架自身前缀(如 Laravel 的 APP_URL、ThinkPHP 的 URL_DOMAIN_DEPLOY),导致浏览器访问的 URL 和路由定义的 path 对不上。
php artisan route:list(Laravel)或 php think route:list(TP6)输出当前有效路由,比对请求路径是否完全匹配(包括开头斜杠、大小写、尾部斜杠)url_common 配置:开启后需用 index.php?s=xxx 形式;关闭后依赖 rewrite,Apache 要启用 .htaccess,Nginx 需配置 try_files $uri $uri/ /index.php?$query_string;
php -S localho
st:8000 router.php,其中 router.php 负责转发所有请求到框架入口/* 示例:Laravel 路由调试入口(临时加在 public/index.php 开头) */ var_dump($_SERVER['REQUEST_URI'], $_SERVER['REQUEST_METHOD']); die;
真正卡住的地方,往往不是路由没写,而是写了但没生效——加载时机、方法限定、中间件拦截、路径偏差,四者占了 404 问题的九成。逐层排除比反复改路由更省时间。