Dans Laravel, le middleware est une fonctionnalité très pratique et importante qui gère le processus entre la requête entrant dans l'application et la réponse renvoyée au client. Au cours de ces processus, vous devrez peut-être effectuer des opérations sur l'utilisateur, telles que vérifier les autorisations de l'utilisateur ou l'authentifier. Si l'utilisateur échoue à votre vérification, vous devrez peut-être le rediriger vers une autre page. Cet article explique comment écrire un middleware dans Laravel pour implémenter le saut middleware.
1. Créer un middleware
Étape 1 : Ouvrez le terminal et utilisez la commande Artisan de Laravel pour créer le middleware :
php artisan make:middleware <middleware-name>
Par exemple :
php artisan make:middleware EnsureUserIsAdmin
Étape 2 : Créez un nouveau middleware dans le répertoire app/Http/Middleware, nommé Assurez-vous queUserIsAdmin. Ce middleware vérifiera si l'utilisateur actuel est déjà connecté et s'il dispose des droits d'administrateur.
namespace App\Http\Middleware; use Closure; use Illuminate\Http\Request; class EnsureUserIsAdmin { public function handle(Request $request, Closure $next){ if (!auth()->check() || !auth()->user()->is_admin) { return redirect('home'); } return $next($request); } }
Dans le code ci-dessus, nous utilisons d'abord la fonction auth() pour vérifier si l'utilisateur actuel est connecté. Si l'utilisateur n'est pas connecté, ce middleware sera redirigé vers la page d'accueil. Si l'utilisateur est déjà connecté, vérifiez s'il dispose des droits d'administrateur. Si l'utilisateur ne dispose pas de droits d'administrateur, le middleware sera redirigé vers la page d'accueil. Sinon, le middleware autorisera la demande à se poursuivre.
2. Utilisation du middleware
Étape 1 : Dans le fichier app/Http/Kernel.php, recherchez le tableau $middlewareGroups. Ce tableau contient les groupes de middleware qui doivent être transmis via l'application.
protected $middlewareGroups = [ 'web' => [ // ... ], 'api' => [ // ... ], ];
Étape 2 : Dans le tableau $middlewareGroups ci-dessus, spécifiez un groupe pour votre nouveau middleware comme suit :
'admin' => [ \App\Http\Middleware\EnsureUserIsAdmin::class, ],
Dans le code ci-dessus, nous utilisons admin comme nom du groupe middleware, ainsi que ce que nous avons fait à l'étape Le nom du middleware créé à l'étape 1 : EnsureUserIsAdmin.
Étape 3 : Maintenant que nous avons créé le middleware lui-même et spécifié où l'utiliser, nous devons maintenant utiliser le middleware dans notre routeur. Ouvrez le fichier routes/web.php et spécifiez que la route utilise le groupe middleware admin, comme indiqué ci-dessous :
Route::get('admin/users', 'Admin\UserController@index')->middleware('admin');
Dans la définition de route ci-dessus, nous utilisons le nom du groupe middleware admin pour protéger les pages accédant à AdminUserController@index.
3. Testez le middleware
Enfin, démarrez votre serveur de développement et testez votre nouveau middleware. Visitez la page du panneau de configuration d'administration de votre application, si vous n'avez pas de droits d'administrateur, vous devriez être redirigé vers la page d'accueil.
Veuillez noter que cet article montre comment créer un middleware pour implémenter des sauts de middleware dans la version Laravel 5.7, cela peut être légèrement différent pour les autres versions.
Résumé
Le middleware est une fonction très utile dans le framework Laravel, qui peut facilement opérer sur les utilisateurs et implémenter des sauts middleware. Dans cet article, nous avons expliqué comment créer et utiliser des middlewares, et comment les utiliser pour protéger des pages ou des ressources spécifiques. Pour les développeurs qui souhaitent renforcer la sécurité de leurs applications, le middleware est un excellent outil pour atteindre cet objectif.
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!