

新闻资讯
技术教程Laravel路由缓存导致404,需执行php artisan optimize:clear(Laravel 8+)或依次运行route:clear、config:clear、view:clear、cache:clear,并重启PHP服务及检查Web服务器伪静态和OPcache。
PHP 缓存旧路由导致 404,本质是 Laravel(或其他框架)把过期的路由配置固化在缓存文件里,routes/web.php 改了但服务器还在用旧的映射表——所以访问新路径直接 404,连错误日志都不报。
运行 php artisan route:list,看输出里有没有你刚加的路由(比如 /dashboard)。如果没出现,基本可以断定:Laravel 没读到你的修改,不是代码写错,而是缓存挡路了。
routes/web.php,刷新浏览器还是 404,甚至 php artisan serve 重启也不管用php artisan route:cache 或 php artisan optimize,缓存就会残留php artisan config:clear 不清路由缓存,php artisan cache:clear 也不一定清干净(尤其 Laravel 8+)别只敲一个 cache:clear ——它不碰路由缓存。必须用专门指令,且推荐统一使用 Laravel 8+ 的新命令,兼容性更好、清理更彻底:
php artisan optimize:clear
这条命令会同时清除:route、config、view、cache 四类缓存。比分别执行四条命令更可靠,也避免遗漏。
optimize:clear,请按顺序执行:php artisan route:clearphp artisan config:cl
earphp artisan view:clearphp artisan cache:clear
Route cache cleared! 字样,否则说明没清成功php artisan serve 前先按 Ctrl + C 停掉旧进程即使清了 Laravel 缓存,404 还在?那可能是 Web 服务器或 PHP 自身在“记仇”:
try_files $uri $uri/ /index.php?$query_string;,请求压根没进 PHP,直接被服务器判为 404。此时清 Laravel 缓存毫无意义routes/web.php,但 OPcache 还在用旧字节码,route:list 看不到新路由。解决方法:service php-fpm-84 restart(以实际服务名为准)真正卡住人的,往往不是 Laravel 缓存本身,而是你以为清完了,其实 Web 服务器或 OPcache 还在固执地返回旧结果。每次清完,务必跑一遍 php artisan route:list 验证,再访问,别凭感觉。