Le middleware fournit un mécanisme pratique pour inspecter et filtrer les requêtes HTTP entrant dans votre application. Par exemple, Lithe inclut un middleware qui vérifie si l'utilisateur est authentifié. Sinon, le middleware redirigera l'utilisateur vers l'écran de connexion. Si l'utilisateur est authentifié, le middleware autorise la demande à se poursuivre.
Dans Lithe, les middlewares sont des fonctions ayant accès à l'objet de requête ($req), à l'objet de réponse ($res) et à la fonction $next dans le cycle requête-réponse de l'application. La fonction $next, lorsqu'elle est invoquée, appelle le middleware suivant dans la pile actuelle.
Les fonctions middleware offrent un moyen pratique d'inspecter, de filtrer et de manipuler les requêtes HTTP entrantes vers votre application. Ils peuvent :
Si le middleware actuel ne termine pas le cycle requête-réponse, il doit appeler $next() pour passer le contrôle au middleware suivant. Dans le cas contraire, la demande restera en attente.
Le code suivant illustre les éléments d'une fonction middleware :
$app->use(function ($req, $res, $next) { $next(); });
Où :
Voici un exemple simple de middleware appelé myLogger. Ce middleware imprime le message LOGGED à chaque fois qu'une requête le traverse. Il est défini comme une fonction affectée à une variable appelée myLogger :
$myLogger = function ($req, $res, $next) { echo 'LOGGED'; $next(); };
Remarquez l'appel $next() ci-dessus. Cette fonction appelle le prochain middleware de l'application. $next() n'est pas une fonction PHP ou Lithe intégrée mais est le troisième argument transmis à la fonction middleware. Bien que $next() puisse être nommé n'importe quoi, par convention, il est toujours appelé « suivant ». Pour éviter toute confusion, respectez cette convention.
Imaginez le middleware comme une série de « couches » traversées par les requêtes HTTP avant d'atteindre votre application. Chaque couche peut examiner ou rejeter la demande.
Pour charger un middleware, vous appelez la méthode use() de la classe LitheApp, en spécifiant la fonction middleware. Par exemple :
$app = new \Lithe\App; $myLogger = function ($req, $res, $next) { echo 'LOGGED'; $next(); }; $app->use($myLogger); $app->get('/', function ($req, $res, $next) { $res->send('Hello World!'); });
Chaque fois que l'application reçoit une demande, le message « LOGGED » sera imprimé. L'ordre de chargement des middlewares est important : ceux chargés en premier sont exécutés en premier.
Le middleware myLogger imprime simplement un message, puis transmet la requête au middleware suivant en utilisant $next().
Une application Lithe peut utiliser les types de middleware suivants :
Vous attachez un middleware au niveau de l'application à une instance de l'application à l'aide des méthodes use() ou METHOD(), où METHOD fait référence à la méthode HTTP (par exemple, GET, PUT, POST) en minuscules.
Cet exemple montre un middleware sans chemin. Le middleware s'exécute à chaque fois qu'une requête est reçue :
$app->use(function ($req, $res, $next) { $next(); });
Dans l'exemple ci-dessous, le middleware gère une requête GET vers le chemin /user/:id:
$myLogger = function ($req, $res, $next) { echo 'LOGGED'; $next(); };
Le middleware au niveau du routeur fonctionne comme un middleware au niveau de l'application mais est attaché à une instance de LitheHttpRouter :
$app = new \Lithe\App; $myLogger = function ($req, $res, $next) { echo 'LOGGED'; $next(); }; $app->use($myLogger); $app->get('/', function ($req, $res, $next) { $res->send('Hello World!'); });
Vous chargez un middleware au niveau du routeur à l'aide des fonctions use() et METHOD().
Voici un exemple de middleware au niveau du routeur :
$app->use(function ($req, $res, $next) { echo 'Hello World!'; $next(); });
Vous pouvez utiliser un middleware tiers pour ajouter des fonctionnalités à vos applications Lithe. Installez le module PHP requis puis chargez-le au niveau de l'application ou du routeur.
Voici un exemple de chargement d'un middleware de session avec LitheMiddlewareSessionsession :
$app->get('/user/:id', function ($req, $res, $next) { if ($req->param('id') === '0') { return $next(); } $res->send('ID is not 0'); }, function ($req, $res) { $res->send('regular'); });
Pour une liste des middlewares tiers couramment utilisés avec Lithe, consultez la ressource Middleware tiers.
Si vous avez besoin que votre middleware soit configurable, vous pouvez créer une fonction qui accepte un tableau d'options ou d'autres paramètres, puis renvoie l'implémentation du middleware en fonction de ces paramètres. Voir l'exemple ci-dessous :
$router = new \Lithe\Http\Router;
Vous pouvez désormais utiliser le middleware avec des configurations personnalisées :
$router = new \Lithe\Http\Router; $router->use(function ($req, $res, $next) { echo 'Time: ', Date('H:i:s'), '<br>'; $next(); }); $router->get('/user/:id', function ($req, $res, $next) { if ($req->param('id') === '0') { $res->redirect('/'); } $next(); }, function ($req, $res) { echo $req->param('id'); $res->render('special'); }); $app->use('/api', $router);
Pour créer un middleware que d'autres développeurs peuvent installer via Composer, il existe un package appelé lithemod/flow. Il fournit des interfaces et des utilitaires pour gérer les requêtes et les réponses HTTP dans Lithe, ce qui facilite la création de middlewares standardisés et prêts à l'emploi dans diverses applications.
lithemod/flow aide à créer des middlewares robustes en fournissant une interface unifiée pour les requêtes et les réponses, rendant le développement plus efficace et organisé. Cela simplifie l'intégration de votre middleware dans d'autres projets et garantit que le code respecte des normes cohérentes.
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!