答案:Laravel控制器通过Artisan命令创建,使用--resource可生成包含7个标准CRUD方法的资源控制器;这些方法对应RESTful路由,需在web.php或api.php中用Route::resource注册,支持only/except过滤;结合Eloquent模型可高效处理数据,API返回JSON建议放在api.php并注意路由缓存清理。

Laravel控制器的创建以及资源控制器的使用是开发Laravel应用的基础技能。通过合理使用控制器,尤其是资源控制器,可以高效组织代码并快速构建符合RESTful规范的路由接口。
创建Laravel控制器
在Laravel中,控制器通常存放在app/Http/Controllers目录下。你可以使用Artisan命令行工具快速生成控制器文件。
打开终端,进入项目根目录,运行以下命令创建一个基础控制器:
php artisan make:controller PostController
该命令会生成一个空的控制器文件PostController.php。如果希望控制器预置一些基本的CRUD方法,可添加--resource选项:
php artisan make:controller PostController --resource
资源控制器详解
使用--resource参数生成的控制器会自动包含7个用于处理资源的标准方法,对应常见的增删改查操作。这些方法分别是:
- index():显示资源列表(GET /posts)
- create():显示创建资源的表单(GET /posts/create)
- store():保存新创建的资源(POST /posts)
- show($id):显示指定资源(GET /posts/{id})
- edit($id):显示编辑资源的表单(GET /posts/{id}/edit)
- update($id):更新指定资源(PUT/PATCH /posts/{id})
- destroy($id):删除指定资源(DELETE /posts/{id})
这些方法与RESTful路由一一对应,便于前后端协作和API设计。
注册资源路由
要在路由中启用资源控制器,需在routes/web.php或routes/api.php中使用Route::resource()方法。
例如,在web路由中注册PostController:
Python v2.4版chm格式的中文手册,内容丰富全面,不但是一本手册,你完全可以把她作为一本Python的入门教程,教你如何使用Python解释器、流程控制、数据结构、模板、输入和输出、错误和异常、类和标准库详解等方面的知识技巧。同时后附的手册可以方便你的查询。
use App\Http\Controllers\PostController;
Route::resource('posts', PostController::class);
执行后,Laravel会自动注册以上7条路由。可通过php artisan route:list命令查看所有已注册的路由及其对应的方法。
若只需部分方法,可使用only或except来过滤:
Route::resource('posts', PostController::class)->only(['index', 'show']);
// 或
Route::resource('posts', PostController::class)->except(['create', 'edit']);
资源控制器的实际应用建议
资源控制器非常适合用于管理具有标准CRUD逻辑的模型,如文章、用户、商品等。
在实际开发中,建议结合Eloquent模型使用。例如在PostController中注入Post模型进行数据操作:
public function index()
{
$posts = Post::all();
return view('posts.index', compact('posts'));
}
对于API开发,可将返回改为JSON格式:
public function index()
{
return response()->json(Post::all());
}
注意:API路由通常放在api.php中,其默认带有/api前缀和无状态特性。
基本上就这些。掌握控制器创建和资源路由的使用,能大幅提升Laravel开发效率。不复杂但容易忽略的是命名规范和路由缓存,记得修改路由后运行php artisan route:clear避免缓存问题。









