Dans Laravel, un contrôleur (Controller) est une classe utilisée pour implémenter certaines fonctions ; le contrôleur peut combiner la logique de traitement des requêtes associée dans une classe distincte. Certaines méthodes sont stockées dans le contrôleur pour implémenter certaines fonctions. Le contrôleur est appelé via le routage, et les fonctions de rappel ne sont plus utilisées ; le contrôleur est stocké dans le répertoire « app/Http/Controllers ».
L'environnement d'exploitation de ce tutoriel : système Windows 7, version Laravel 6, ordinateur DELL G3.
1. Qu'est-ce qu'un contrôleur ?
Afin de remplacer toute la logique de traitement des requêtes définie sous forme de fermetures dans le fichier de routage, vous souhaiterez peut-être utiliser des classes de contrôle pour organiser ces comportements. Les contrôleurs peuvent regrouper la logique de traitement des demandes associée dans une classe distincte.
Controller est une classe utilisée pour implémenter certaines fonctions. Certaines méthodes sont stockées dans le contrôleur pour implémenter certaines fonctions. Le contrôleur est appelé via le routage et les fonctions de rappel ne sont plus utilisées.
2. Où est écrit le contrôleur ?
App/Http/Controllers place le contrôleur
Controller.php est le fichier de classe parent, d'autres contrôleurs peuvent hériter
3. Comment nommer le fichier du contrôleur ?
Nom du contrôleur Hump-hump + Controller.php
Par exemple, AddDataController.php LoginController.php
4. Comment écrire la structure du contrôleur ?
Généré automatiquement via des commandes artisanales, par exemple : Assurez-vous que dans le répertoire racine du projet en cours, saisissez la ligne de commande :
php artisan make:controller TestController
Achèvement automatique du code de structure,
namespace App\Http\Controller; use Illuminate\Http\Request; class TestController extends Controller{ // }
Définir le contrôleur
Vous trouverez ci-dessous un exemple de classe de contrôleur de base. A noter que ce contrôleur hérite du contrôleur de base de Laravel
. Cette classe de contrôleur fournit des méthodes pratiques, telles que la méthode middleware
, qui peut ajouter un middleware au comportement du contrôleur : Laravel
的基础控制器。该类控制器提供了一些便利的方法,比如 middleware
方法,该方法可以为控制器行为添加中间件:
<?php namespace App\Http\Controllers; use App\Http\Controllers\Controller; use App\Models\User; class UserController extends Controller { /** * 显示指定用户的简介 * * @param int $id * @return \Illuminate\View\View */ public function show($id) { return view('user.profile', ['user' => User::findOrFail($id)]); } }
你可以像这样定义一个指向控制器行为的路由:
use App\Http\Controllers\UserController; Route::get('user/{id}', [UserController::class, 'show']);
当一个请求与指定路由的 URI 匹配时, UserController
控制器中的 show
方法将会执行。路由参数也将会被传递给该方法。
技巧:控制器并不是 必需 继承基础类。如果控制器没有继承基础类,你将无法使用一些便捷的功能,比如
middleware
,validate
,和dispatch
方法。
单行为控制器
如果你想要定义一个只处理单个行为的控制器,你可以在控制器中放置一个 __invoke
方法:
<?php namespace App\Http\Controllers; use App\Http\Controllers\Controller; use App\Models\User; class ShowProfile extends Controller { /** * 显示指定用户的简介 * * @param int $id * @return \Illuminate\View\View */ public function __invoke($id) { return view('user.profile', ['user' => User::findOrFail($id)]); } }
当注册单个行为控制器的路由时不需要指名方法:
use App\Http\Controllers\ShowProfile; Route::get('user/{id}', ShowProfile::class);
你可以通过 Artisan 命令工具里的 make:controller
命令中的 --invokable
选项来生成一个可调用的控制器
php artisan make:controller ShowProfile --invokable
技巧:可以使用 stub 定制 自定义控制器模板
中间件 可以在路由文件中分配给控制器的路由:
Route::get('profile', [UserController::class, 'show'])->middleware('auth');
然而,在控制器的构造函数中指定中间件更为方便。使用控制器构造函数中的 middleware
方法,可以轻松地将中间件分配给控制器。你甚至可以将中间件限制为只在控制器中的某些方法生效:
class UserController extends Controller { /** * 实例化一个新的控制器实例 * * @return void */ public function __construct() { $this->middleware('auth'); $this->middleware('log')->only('index'); $this->middleware('subscribed')->except('store'); } }
同时,控制器还允许你使用一个闭包来注册中间件。这为不定义整个中间件类的情况下为单个控制器定义中间件提供了一种便捷的方法:
$this->middleware(function ($request, $next) { // ... return $next($request); });
技巧:你可以将中间件分配给控制器操作的一个子集。然而,它可能表明你的控制器正在变得复杂。建议你将控制器拆分为多个较小的控制器。
Laravel 的资源路由通过单行代码即可将典型的「CURD (增删改查)」路由分配给控制器。例如,你希望创建一个控制器来处理保存 “照片” 应用的所有 HTTP 请求。使用 Artisan 命令 make:controller
可以快速创建这样一个控制器:
php artisan make:controller PhotoController --resource
这个命令将会生成一个控制器 app/Http/Controllers/PhotoController.php
。 其中包括每个可用资源操作的方法。
接下来,你可以给控制器注册一个资源路由:
Route::resource('photos', PhotoController::class);
这个单一的路由声明创建了多个路由来处理资源上的各种行为。生成的控制器为每个行为保留了方法,包括了关于处理 HTTP 动词和 URLs 的声明注释。
你可以通过将数组传参到 resources
Route::resources([ 'photos' => PhotoController::class, 'posts' => PostController::class, ]);Vous pouvez définir une route pointant vers le comportement du contrôleur comme ceci :
php artisan make:controller PhotoController --resource --model=PhotoLorsqu'une requête correspond à l'URI de la route spécifiée, la méthode
show
dans le contrôleur UserController
sera exécutée. Les paramètres d'itinéraire seront également transmis à cette méthode. middleware
, le validate
et le dispatchcode> méthodes. 🎜🎜🎜🎜Contrôleur de comportement unique🎜🎜🎜🎜Si vous souhaitez définir un contrôleur qui ne gère qu'un seul comportement, vous pouvez placer une méthode <code>__invoke
dans le contrôleur : 🎜Route::resource('photos', PhotoController::class)->only([ 'index', 'show' ]); Route::resource('photos', PhotoController::class)->except([ 'create', 'store', 'update', 'destroy' ]);🎜Lors de l'enregistrement d'un seul comportement Il n'est pas nécessaire de spécifier la méthode lors du routage du contrôleur de comportement : 🎜
Route::apiResource('photos', PhotoController::class);🎜Vous pouvez générer une méthode invocable via l'option
--invokable
dans la commande make:controller
dans l'outil de commande Artisan appelé contrôleur 🎜Route::apiResources([ 'photos' => PhotoController::class, 'posts' => PostController::class, ]);🎜🎜 Conseils : vous pouvez utiliser la personnalisation du stub pour personnaliser le modèle du contrôleur 🎜🎜🎜🎜 au milieu du contrôleur 🎜🎜🎜Middleware peut être attribué à la route du contrôleur dans le fichier de route : 🎜
php artisan make:controller API/PhotoController --api🎜 Cependant, dans le contrôleur, il est plus pratique de spécifier le middleware dans le constructeur. Le middleware peut être facilement attribué à un contrôleur à l'aide de la méthode
middleware
dans le constructeur du contrôleur. Vous pouvez même restreindre le middleware à ne prendre effet que sur certaines méthodes du contrôleur : 🎜Route::resource('photos.comments', PhotoCommentController::class);🎜 En même temps, le contrôleur vous permet également d'enregistrer le middleware à l'aide d'une fermeture. Cela constitue un moyen pratique de définir un middleware pour un seul contrôleur sans définir la classe entière du middleware : 🎜
/photos/{photo}/comments/{comment}🎜🎜 Astuce : vous pouvez attribuer un middleware à un sous-ensemble d'actions du contrôleur. Cependant, cela peut être le signe que votre contrôleur devient complexe. Il est recommandé de diviser le contrôleur en plusieurs contrôleurs plus petits. 🎜🎜🎜🎜Resource Controller🎜🎜🎜🎜Le routage des ressources de Laravel peut attribuer des itinéraires typiques « CURD (Créer, Supprimer, Modifier) » aux contrôleurs avec une seule ligne de code. Par exemple, vous souhaitez créer un contrôleur qui gère toutes les requêtes HTTP pour l'application Save Photos. Utilisez la commande Artisan
make:controller
pour créer rapidement un tel contrôleur : 🎜Route::resource('photos.comments', PhotoCommentController::class)->scoped([ 'comment' => 'slug', ]);🎜Cette commande générera un contrôleur
app/Http/Controllers/PhotoController.php
. Cela inclut des méthodes pour chaque opération de ressource disponible. 🎜🎜Ensuite, vous pouvez enregistrer une route de ressource auprès du contrôleur : 🎜/photos/{photo}/comments/{comment:slug}🎜Cette déclaration de route unique crée plusieurs routes pour gérer différents comportements sur la ressource. Le contrôleur généré conserve les méthodes pour chaque action, y compris les annotations déclaratives pour la gestion des verbes HTTP et des URL. 🎜🎜Vous pouvez créer plusieurs contrôleurs de ressources à la fois en passant les paramètres du tableau à la méthode
resources
: 🎜Route::resource('photos.comments', CommentController::class)->shallow();🎜🎜Traitement des opérations du contrôleur de ressources🎜🎜🎜
Verb | URI | Action | Route Name |
---|---|---|---|
GET | /photos |
index | photos.index |
GET | /photos/create |
create | photos.create |
POST | /photos |
store | photos.store |
GET | /photos/{photo} |
show | photos.show |
GET | /photos/{photo}/edit |
edit | photos.edit |
PUT/PATCH | /photos/{photo} |
update | photos.update |
DELETE | /photos/{photo} |
destroy | photos.destroy |
指定资源模型
如果你使用了路由模型绑定,并且想在资源控制器的方法中使用类型提示,你可以在生成控制器的时候使用 --model
选项:
php artisan make:controller PhotoController --resource --model=Photo
当声明资源路由时,你可以指定控制器处理的部分行为,而不是所有默认的行为:
Route::resource('photos', PhotoController::class)->only([ 'index', 'show' ]); Route::resource('photos', PhotoController::class)->except([ 'create', 'store', 'update', 'destroy' ]);
API 资源路由
当声明用于 APIs 的资源路由时,通常需要排除显示 HTML 模板的路由(如 create
和 edit
)。为了方便起见,你可以使用 apiResource
方法自动排除这两个路由:
Route::apiResource('photos', PhotoController::class);
你也可以传递一个数组给 apiResources
方法来同时注册多个 API 资源控制器:
Route::apiResources([ 'photos' => PhotoController::class, 'posts' => PostController::class, ]);
要快速生成不包含 create
或 edit
方法的用于开发接口的资源控制器,请在执行 make:controller 命令时使用 --api
参数:
php artisan make:controller API/PhotoController --api
有时可能需要定义一个嵌套的资源型路由。例如,照片资源可能被添加了多个评论。那么可以在路由中使用 “点” 符号来声明资源型控制器:
Route::resource('photos.comments', PhotoCommentController::class);
该路由会注册一个嵌套资源,可以使用如下 URI
访问:
/photos/{photo}/comments/{comment}
限定嵌套资源的范围
Laravel 的 隐式模型绑定 特性可以自动限定嵌套绑定的范围,因此已解析的子模型会自动属于父模型。定义嵌套路由时,使用 scoped
方法,可以开启自动范围限定,也可以指定 Laravel 应该按照哪个字段检索子模型资源
Route::resource('photos.comments', PhotoCommentController::class)->scoped([ 'comment' => 'slug', ]);
这个路由会注册一个限定范围的嵌套资源路由,可以像下面这样来访问:
/photos/{photo}/comments/{comment:slug}
浅层嵌套
通常,并不完全需要在 URI
中同时拥有父 ID 和子 ID ,因为子 ID 已经是唯一的标识符。当使用唯一标识符(如自动递增的主键)来标识 URI
中的模型时,可以选择使用「浅嵌套」的方式定义路由:
Route::resource('photos.comments', CommentController::class)->shallow();
上面的路由定义方式会定义以下路由:
HTTP 方式 | URI | 行为 | 路由名称 |
---|---|---|---|
GET | /photos/{photo}/comments |
index | photos.comments.index |
GET | /photos/{photo}/comments/create |
create | photos.comments.create |
POST | /photos/{photo}/comments |
store | photos.comments.store |
GET | /comments/{comment} |
show | comments.show |
GET | /comments/{comment}/edit |
edit | comments.edit |
PUT/PATCH | /comments/{comment} |
update | comments.update |
DELETE | /comments/{comment} |
destroy | comments.destroy |
默认情况下,所有的资源控制器行为都有一个路由名称。你可以传入 names
数组来覆盖这些名称:
Route::resource('photos', PhotoController::class)->names([ 'create' => 'photos.build' ]);
默认情况下,Route::resource
会根据资源名称的「单数」形式创建资源路由的路由参数。你可以在选项数组中传入 parameters
参数来轻松地覆盖每个资源。parameters
数组应该是资源名称和参数名称的关联数组:
Route::resource('users', AdminUserController::class)->parameters([ 'users' => 'admin_user' ]);
上例将会为资源的 show
路由生成如下的 URI :
/users/{admin_user}
有时,在定义资源路由时隐式绑定了多个 Eloquent 模型,你希望限定第二个 Eloquent 模型必须为第一个 Eloquent 模型的子模型。例如,考虑这样一个场景,通过 slug 检索某个特殊用户的一篇文章:
use App\Http\Controllers\PostsController;Route::resource('users.posts', PostsController::class)->scoped();
你可以通过给 scoped
方法传递一个数组来覆盖默认的模型路由键:
use App\Http\Controllers\PostsController;Route::resource('users.posts', PostsController::class)->scoped([ 'post' => 'slug', ]);
当使用一个自定义键的隐式绑定作为嵌套路由参数时,Laravel 会自动限定查询范围,按照约定的命名方式去父类中查找关联方法,然后检索到对应的嵌套模型。在这种情况下,将假定 User
模型有一个叫 posts
(路由参数名的复数)的关联方法,通过这个方法可以检索到 Post
模型。
默认情况下,Route::resource
将会用英文动词创建资源 URI。如果需要自定义 create
和 edit
行为的动作名,可以在 AppServiceProvider
的 boot
中使用 Route::resourceVerbs
方法实现:
use Illuminate\Support\Facades\Route; /** * 引导任何应用服务。 * * @return void */ public function boot() { Route::resourceVerbs([ 'create' => 'crear', 'edit' => 'editar', ]); }
动作被自定义后,像 Route::resource('fotos', 'PhotoController')
这样注册的资源路由将会产生如下的 URI:
/fotos/crear /fotos/{foto}/editar
如果您需要增加额外的路由到默认的资源路由之中,您需要在 Route::resource
前定义它们;否则, resource
方法定义的路由可能会无意间优先于您定义的路由:
Route::get('photos/popular', [PhotoController::class, 'popular']); Route::resource('photos', PhotoController::class);
技巧:记得保持您的控制器的专一性。如果您需要典型的资源操作以外的方法,请考虑将您的控制器分割为两个更小的控制器。
构造注入
Laravel 服务容器 被用于解析所有的 Laravel 控制器。因此,您可以在控制器的构造函数中使用类型提示需要的依赖项。声明的解析会自动解析并注入到控制器实例中去:
<?php namespace App\Http\Controllers; use App\Repositories\UserRepository; class UserController extends Controller { /** * 用户 repository 实例。 */ protected $users; /** * 创建一个新的控制器实例。 * * @param UserRepository $users * @return void */ public function __construct(UserRepository $users) { $this->users = $users; } }
您亦可类型提示 Laravel 契约 ,只要它能够被解析。取决于您的应用,注入依赖到控制器可能会提供更好的可测试性。
方法注入
除了构造器注入以外,您亦可在控制器方法中类型提示依赖。最常见的用法便是注入 Illuminate\Http\Request
到您的控制器方法中:
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; class UserController extends Controller { /** * 保存一个新用户。 * * @param Request $request * @return Response */ public function store(Request $request) { $name = $request->name; // } }
如果您的控制器方法要从路由参数中获取输入内容,请在您的依赖项之后列出您的路由参数。例如,您可以像下方这样定义路由:
Route::put('user/{id}', [UserController::class, 'update']);
如下所示,您依然可以类型提示 Illuminate\Http\Request
并通过定义您的控制器方法访问 id
参数:
<?php namespace App\Http\Controllers; use Illuminate\Http\Request; class UserController extends Controller { /** * 修改指定的用户。 * * @param Request $request * @param string $id * @return Response */ public function update(Request $request, $id) { // } }
如果您的应用仅使用了基于路由的控制器,您应该充分利用 Laravel 路由缓存。使用路由缓存将会大幅降低您的应用路由的注册时间。有时,您的路由注册的速度可能会提高 100 倍。要生成路由缓存,仅需执行 route:cache
Artisan 命令:
php artisan route:cache
在运行该命令后,每次请求将会加载您缓存的路由文件。请记住,您每次添加新路由后均需要生成新的路由缓存。因此,您应该在项目部署时才运行 route:cache
命令。
您亦可使用 route:clear
来清除路由缓存:
php artisan route:clear
【相关推荐:laravel视频教程】
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!