Laravel - Intergiciel

L'intergiciel agit comme un pont entre une demande et une réponse. C'est un type de mécanisme de filtrage. Ce chapitre vous explique le mécanisme middleware de Laravel.

Laravel inclut un middleware qui vérifie si l'utilisateur de l'application est authentifié ou non. Si l'utilisateur est authentifié, il redirige vers la page d'accueil sinon, sinon, il redirige vers la page de connexion.

Le middleware peut être créé en exécutant la commande suivante -

php artisan make:middleware <middleware-name>

Remplace le <middleware-name>avec le nom de votre middleware. Le middleware que vous créez est visible surapp/Http/Middleware annuaire.

Exemple

Observez l'exemple suivant pour comprendre le mécanisme du middleware -

Step 1- Créons maintenant AgeMiddleware. Pour créer cela, nous devons exécuter la commande suivante -

php artisan make:middleware AgeMiddleware

Step 2 - Après une exécution réussie de la commande, vous recevrez la sortie suivante -

Step 3 - AgeMiddleware sera créé à app/Http/Middleware. Le fichier nouvellement créé aura le code suivant déjà créé pour vous.

<?php

namespace App\Http\Middleware;
use Closure;

class AgeMiddleware {
   public function handle($request, Closure $next) {
      return $next($request);
   }
}

Enregistrement du middleware

Nous devons enregistrer chaque middleware avant de l'utiliser. Il existe deux types de middleware dans Laravel.

  • Middleware mondial
  • Middleware de route

le Global Middleware s'exécutera à chaque requête HTTP de l'application, alors que le Route Middlewaresera affecté à un itinéraire spécifique. Le middleware peut être enregistré surapp/Http/Kernel.php. Ce fichier contient deux propriétés $middleware et $routeMiddleware. $middleware propriété est utilisée pour enregistrer Global Middleware et $routeMiddleware La propriété est utilisée pour enregistrer un middleware spécifique à une route.

Pour enregistrer le middleware global, répertoriez la classe à la fin de la propriété $ middleware.

protected $middleware = [
   \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
   \App\Http\Middleware\EncryptCookies::class,
   \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
   \Illuminate\Session\Middleware\StartSession::class,
   \Illuminate\View\Middleware\ShareErrorsFromSession::class,
   \App\Http\Middleware\VerifyCsrfToken::class,
];

Pour enregistrer le middleware spécifique à la route, ajoutez la clé et la valeur à la propriété $ routeMiddleware.

protected $routeMiddleware = [
   'auth' => \App\Http\Middleware\Authenticate::class,
   'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
   'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
];

Exemple

Nous avons créé AgeMiddlewaredans l'exemple précédent. Nous pouvons maintenant l'enregistrer dans la propriété middleware spécifique à la route. Le code de cet enregistrement est indiqué ci-dessous.

Voici le code pour app/Http/Kernel.php -

<?php

namespace App\Http;
use Illuminate\Foundation\Http\Kernel as HttpKernel;

class Kernel extends HttpKernel {
   protected $middleware = [
      \Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
      \App\Http\Middleware\EncryptCookies::class,
      \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
      \Illuminate\Session\Middleware\StartSession::class,
      \Illuminate\View\Middleware\ShareErrorsFromSession::class,
      \App\Http\Middleware\VerifyCsrfToken::class,
   ];
  
   protected $routeMiddleware = [
      'auth' => \App\Http\Middleware\Authenticate::class,
      'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
      'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
      'Age' => \App\Http\Middleware\AgeMiddleware::class,
   ];
}

Paramètres du middleware

Nous pouvons également passer des paramètres avec le middleware. Par exemple, si votre application a différents rôles tels que l'utilisateur, l'administrateur, le super-administrateur, etc. et que vous souhaitez authentifier l'action en fonction du rôle, cela peut être réalisé en passant des paramètres avec le middleware. Le middleware que nous créons contient la fonction suivante et nous pouvons passer notre argument personnalisé après le$next argument.

public function handle($request, Closure $next) {
   return $next($request);
}

Exemple

Step 1 - Créez RoleMiddleware en exécutant la commande suivante -

php artisan make:middleware RoleMiddleware

Step 2 - Après une exécution réussie, vous recevrez la sortie suivante -

Step 3 - Ajoutez le code suivant dans la méthode handle du RoleMiddlewareat nouvellement créé app/Http/Middleware/RoleMiddleware.php.

<?php

namespace App\Http\Middleware;
use Closure;

class RoleMiddleware {
   public function handle($request, Closure $next, $role) {
      echo "Role: ".$role;
      return $next($request);
   }
}

Step 4 - Enregistrez le RoleMiddleware dans app\Http\Kernel.phpfichier. Ajoutez la ligne surlignée en gris dans ce fichier pour enregistrer RoleMiddleware.

Step 5 - Exécutez la commande suivante pour créer TestController -

php artisan make:controller TestController --plain

Step 6 - Après l'exécution réussie de l'étape ci-dessus, vous recevrez la sortie suivante -

Step 7 - Copiez les lignes de code suivantes dans app/Http/TestController.php fichier.

app/Http/TestController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class TestController extends Controller {
   public function index() {
      echo "<br>Test Controller.";
   }
}

Step 8 - Ajoutez la ligne de code suivante dans app/Http/routes.php fichier.

app/Http/routes.php

Route::get('role',[
   'middleware' => 'Role:editor',
   'uses' => 'TestController@index',
]);

Step 9 - Visitez l'URL suivante pour tester le middleware avec des paramètres

http://localhost:8000/role

Step 10 - La sortie apparaîtra comme indiqué dans l'image suivante.

Intergiciel terminable

L'intergiciel terminable effectue une tâche après l'envoi de la réponse au navigateur. Cela peut être accompli en créant un middleware avecterminateméthode dans le middleware. Le middleware terminable doit être enregistré auprès du middleware global. La méthode terminate recevra deux arguments$request et $response. La méthode Terminate peut être créée comme indiqué dans le code suivant.

Exemple

Step 1 - Créer TerminateMiddleware en exécutant la commande ci-dessous.

php artisan make:middleware TerminateMiddleware

Step 2 - L'étape ci-dessus produira la sortie suivante -

Step 3 - Copiez le code suivant dans le nouveau TerminateMiddleware à app/Http/Middleware/TerminateMiddleware.php.

<?php

namespace App\Http\Middleware;
use Closure;

class TerminateMiddleware {
   public function handle($request, Closure $next) {
      echo "Executing statements of handle method of TerminateMiddleware.";
      return $next($request);
   }
   
   public function terminate($request, $response) {
      echo "<br>Executing statements of terminate method of TerminateMiddleware.";
   }
}

Step 4 - Enregistrez le TerminateMiddleware dans app\Http\Kernel.phpfichier. Ajoutez la ligne surlignée en gris dans ce fichier pour enregistrer TerminateMiddleware.

Step 5 - Exécutez la commande suivante pour créer ABCController.

php artisan make:controller ABCController --plain

Step 6 - Après l'exécution réussie de l'URL, vous recevrez la sortie suivante -

Step 7 - Copiez le code suivant dans app/Http/ABCController.php fichier.

app/Http/ABCController.php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Http\Requests;
use App\Http\Controllers\Controller;

class ABCController extends Controller {
   public function index() {
      echo "<br>ABC Controller.";
   }
}

Step 8 - Ajoutez la ligne de code suivante dans app/Http/routes.php fichier.

app/Http/routes.php

Route::get('terminate',[
   'middleware' => 'terminate',
   'uses' => 'ABCController@index',
]);

Step 9 - Visitez l'URL suivante pour tester l'intergiciel terminable.

http://localhost:8000/terminate

Step 10 - La sortie apparaîtra comme indiqué dans l'image suivante.