控制器方法名大小写不匹配、未声明为public、路由未正确绑定、缓存未清除是导致404的四大主因,需逐项排查。
PHP框架(如 Laravel、ThinkPHP、CodeIgniter)默认对控制器方法名区分大小写。如果你在路由中访问 index,但实际定义的是 Index 或 INDEX,绝大多数框架会直接返回 404 —— 它根本不会尝试匹配。
showUser;ThinkPHP 6 默认要求小写加下划线,如 user_list)Rou
te::get('/user', [UserController::class, 'show']) 中的 'show' 必须对应控制器里 public function show(),不能是 public function Show()
很多新手把控制器方法写成 private 或 protected,框架无法调用,就跳过该方法,最终找不到可执行逻辑而报 404。
public
public 关键字,尤其复制粘贴旧代码时容易漏掉即使方法名拼写正确、权限正确,如果路由没指向它,照样 404。常见于手动注册路由或使用资源路由时配置偏差。
php artisan route:list 查看实际注册的路由,确认目标 URI 对应的 Action 列是否为你的控制器@方法route/app.php 是否有显式绑定,或是否启用了「自动解析」但控制器/方法命名不符合约定$routes->add('user', 'User::profile') 中的 User::profile 是否拼写准确,类名大小写也要匹配文件名修改控制器方法名或路由配置后,框架常缓存路由表,你改了代码但请求仍走老路径,结果还是 404。
php artisan route:clear 和 php artisan config:clear
php think clear 或手动删掉 runtime/cache/ 下所有文件writable/cache/ 目录内容php artisan route:list | grep user
真正卡住的地方往往不是“怎么写”,而是“你以为它在调这个方法,其实它压根没看到”。多看一遍 route:list 输出,比反复改方法名更有效。