laravel 路由在 routes/web.php 中定义,支持闭包、控制器方法绑定及资源路由;控制器用 php artisan make:controller 创建,配合命名路由和中间件实现高效开发。

在 Laravel 中,路由负责接收请求并分发给控制器处理,控制器则封装具体的业务逻辑。定义路由和控制器是构建 Web 应用的第一步,下面用最常用、最清晰的方式说明。
定义基础路由(web.php)
Laravel 的前端路由默认写在 routes/web.php 文件中,所有带 session、csrf 保护的页面请求都走这里。
- GET 请求:访问首页显示欢迎页
Route::get('/', function () { return view('welcome'); });
- 带参数的 GET 路由:如 /user/123
Route::get('/user/{id}', function ($id) { return '用户ID是:' . $id; });
- 绑定到控制器方法(推荐方式)
Route::get('/posts', [PostController::class, 'index']);
生成控制器并编写方法
用 Artisan 命令快速创建控制器:
php artisan make:controller PostController
生成的控制器位于 app/http/Controllers/PostController.php,默认包含空的 index() 方法。补充如下:
namespace appHttpControllers; use IlluminateHttpRequest; class PostController extends Controller { public function index() { return view('posts.index', ['posts' => []]); } public function show($id) { return "查看文章 ID:{$id}"; } }
然后在路由中注册对应方法:
Route::get('/posts', [PostController::class, 'index']); Route::get('/post/{id}', [PostController::class, 'show']);
使用资源路由(批量定义 CRUD)
对标准增删改查场景,Laravel 提供 Resource() 方法一键注册 7 个 restful 路由:
Route::resource('photos', PhotoController::class);
它会自动映射:
- GET /photos → index
- GET /photos/create → create
- POST /photos → store
- GET /photos/{photo} → show
- GET /photos/{photo}/edit → edit
- PUT/PATCH /photos/{photo} → update
- delete /photos/{photo} → destroy
运行 php artisan route:list 可查看所有已注册路由。
命名路由与中间件(实用增强)
给路由起名字,方便在模板或重定向中引用:
Route::get('/dashboard', [AdminController::class, 'index']) ->name('admin.dashboard');
在 Blade 模板中可这样跳转:
<a href="{{ route('admin.dashboard') }}">后台首页</a>
添加中间件控制访问权限(比如只允许登录用户):
Route::get('/profile', [ProfileController::class, 'edit']) ->middleware('auth') ->name('profile.edit');
基本上就这些。路由定义简洁明确,控制器职责单一,配合 Artisan 命令,搭建页面逻辑非常高效。