


Quelles sont les différences entre le middleware front-end et le middleware back-end de ThinkPHP6 ?
Dans le dernier exemple, nous avons appris à définir le middleware et compris la signification du middleware. Ensuite, nous avons feuilleté le manuel et en avons trouvé un autre appelé « pré-middleware » et « post-middleware ». Quelle est la différence entre les deux ?
1. La différence dans les définitions.
Il n'est pas difficile de trouver dans le manuel du site officiel que les définitions du pré-middleware et du post-middleware sont différentes. Jetons un coup d'œil ci-dessous.
Définition pré-middleware :
<?php namespace app\middleware; class Before { public function handle($request, \Closure $next) { // 添加中间件执行代码 return $next($request); } }
Post-middleware :
<?php namespace app\middleware; class After { public function handle($request, \Closure $next) { $response = $next($request); // 添加中间件执行代码 return $response; } }
Après un examen plus approfondi, j'ai découvert qu'en dernière analyse, les deux sont du code d'exécution et $next . ($request) problème d'ordre, c'est cet ordre qui est la clé du pré-middleware et du post-middleware.
2. $request est différent.
Nous pouvons imprimer les codes suivants respectivement dans le pré-middleware et le post-middleware :
halt($request);
Nous avons soigneusement comparé et constaté que les contrôleurs et les méthodes du pré-middleware le middleware est vide, le post-middleware peut obtenir le nom et la méthode du contrôleur. Donc, si nous voulons obtenir le contrôleur et la méthode actuellement consultés, nous devons utiliser un post-middleware pour le résoudre.
3. Le middleware intercepte le scénario de connexion.
Jetons d'abord un coup d'œil à la définition du middleware proposée sur le site officiel :
Le middleware est principalement utilisé pour intercepter ou filtrer les requêtes HTTP des applications et effectuer les opérations nécessaires. traiter avec.
En voyant la définition du site officiel, vous pensez peut-être qu'utiliser un middleware pour l'interception des connexions est vraiment la meilleure chose. Mais faut-il utiliser le pré- ou le post-middleware ?
<?php namespace app\middleware; class After { public function handle($request, \Closure $next) { $response = $next($request); // 添加中间件执行代码 if(empty('session')){ echo '登录不合法'; //跳转到登录页面 } return $response; } }
Page d'accueil du backend :
public function index(){ echo '后台首页'; }
Le résultat de l'exécution constatera que nous pouvons toujours exécuter la méthode d'index avant le saut de connexion et que nous pouvons afficher le contenu.
Par conséquent, le post-middleware ne peut pas être utilisé dans les scénarios de connexion. Le pré-middleware est la meilleure solution pour intercepter la connexion. À ce stade, il est également nécessaire de déterminer si l'accès actuel est une connexion. , de nombreux problèmes apparaîtront lors de la redirection, les amis doivent donc bien gérer cela.
Ce qui précède est l'introduction pertinente au pré- et post-middleware. Dans les projets réels, nous déterminons s'il convient d'utiliser le pré- ou le post-middleware en fonction de notre logique métier réelle.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Cet article montre la création d'applications de ligne de commande (CLI) en utilisant les capacités CLI de ThinkPhp. Il met l'accent sur les meilleures pratiques telles que la conception modulaire, l'injection de dépendance et la gestion des erreurs robuste, tout en mettant en évidence les pièges communs tels que INSU

L'article traite des considérations clés pour l'utilisation de ThinkPHP dans des architectures sans serveur, en se concentrant sur l'optimisation des performances, la conception sans état et la sécurité. Il met en évidence des avantages tels que la rentabilité et l'évolutivité, mais relève également des défis

Le conteneur IOC de ThinkPhp propose des fonctionnalités avancées comme le chargement paresseux, la liaison contextuelle et l'injection de méthode pour une gestion efficace des dépendances dans les applications PHP. COMMANDE CHARACTER: 159

L'article discute de la prévention des vulnérabilités d'injection SQL dans ThinkPhP à travers des requêtes paramétrées, en évitant le SQL brut, en utilisant ORM, des mises à jour régulières et une bonne gestion des erreurs. Il couvre également les meilleures pratiques pour sécuriser les requêtes de base de données et le validat

L'article décrit la création d'un système de file d'attente de tâches distribué à l'aide de ThinkPhp et RabbitMQ, en se concentrant sur l'installation, la configuration, la gestion des tâches et l'évolutivité. Les problèmes clés incluent assurer la haute disponibilité, éviter les pièges communs comme Imprope

L'article traite du cadre de test intégré de ThinkPhP, mettant en évidence ses principales fonctionnalités telles que les tests d'unité et d'intégration, et comment il améliore la fiabilité des applications grâce à la détection précoce des bogues et à une meilleure qualité de code.

L'article traite des différences clés entre ThinkPHP 5 et 6, en se concentrant sur l'architecture, les fonctionnalités, les performances et l'adéquation pour les mises à niveau héritées. ThinkPhp 5 est recommandé pour les projets traditionnels et les systèmes hérités, tandis que ThinkPhp 6 convient au nouveau PR

L'article traite des meilleures pratiques pour gérer les téléchargements de fichiers et intégrer le stockage cloud dans ThinkPHP, en se concentrant sur la sécurité, l'efficacité et l'évolutivité.
