Le middleware ThinkPHP6.0 est divisé en middleware système et middleware d'application. Le middleware système est le middleware intégré au framework principal, et le middleware d'application est le middleware créé dans l'application.
Les principaux scénarios d'application du middleware peuvent inclure le filtrage des données, la détection des autorisations, l'interception des requêtes et d'autres comportements pour les requêtes HTTP. L'utilisation d'un middleware peut simplifier la définition du contrôleur et gérer de nombreux processus métier supplémentaires non essentiels. peut être transmis au middleware pour exécution.
Du point de vue de la portée d'utilisation du middleware, il peut être divisé en middleware global, middleware d'application, middleware de contrôleur et middleware de routage.
Middleware global
Le middleware global est le middleware défini dans appmiddleware.php Aucun middleware n'est activé par défaut, mais il le fait pour les middlewares système pris en charge. vous devez décommenter pour utiliser le middleware système correspondant. Le contenu par défaut est le suivant :
return [ // 全局请求缓存 // 'think\middleware\CheckRequestCache', // 多语言加载 // 'think\middleware\LoadLangPack', // Session初始化 // 'think\middleware\SessionInit', // 页面Trace调试 // 'think\middleware\TraceDebug', ];
Certaines fonctions du système sont confiées au middleware pour une gestion unifiée, notamment la mise en cache globale des requêtes et la détection automatique multilingue. Et le chargement, l'initialisation de session et le débogage de trace de page, c'est-à-dire que l'application installée par défaut ne prend pas en charge Session. Vous devez activer le middleware d'initialisation de session globalement avant que Session puisse prendre effet. Pour les applications API, la prise en charge de la fonction Session n'est pas requise.
Vous pouvez ajouter votre middleware d'application dans le fichier de définition global du middleware, mais essayez de vous assurer que le middleware système est exécuté en premier. La définition du middleware doit utiliser le nom de classe complet, qui peut être rapidement créé via la ligne de commande. instructions. Un middleware d'application :
php think make:middleware Test
générera automatiquement une classe middleware appmiddlewareTest avec le contenu suivant :
<?php namespace app\middleware; class Test { public function handle($request, \Closure $next) { } }
prend également en charge la création de classes middleware en spécifiant l'espace de noms complet
php think make:middleware app\middleware\Hello
<?php namespace app\middleware; class Test { public function handle($request, \Closure $next) { echo 'Before Middleware<br/>'; $response = $next($request); echo 'After Middleware<br/>'; return $response; } }
return [ \app\middleware\Test::class, ];
<?php namespace app\controller; class Index { public function hello() { return 'Hello,ThinkPHP!<br/>'; } }
Before Middleware Hello,ThinkPHP! After Middleware
S'il s'agit d'un mode multi-application, le middleware d'application est le middleware défini dans le nom de l'application middleware.php, et ne sera utilisé que dans cette application Valable ci-dessous, le format de définition est cohérent avec le middleware global.
Middleware de routageLe middleware de routage signifie qu'un certain middleware ne sera exécuté qu'après la correspondance de la route. Il est défini à l'aide de la méthode middleware dans la définition de la route, par exemple. exemple :
Route::get('hello/:name','index/hello') ->middleware(\app\middleware\Hello::class);
Vous pouvez définir un middleware pour les groupes de routage
Route::group(function(){ Route::get('hello/:name','index/hello'); //... })->middleware(\app\middleware\Hello::class);
Si vous souhaitez exécuter plusieurs middleware, vous pouvez utiliser
Route::group(function(){ Route::get('hello/:name','index/hello'); //... })->middleware([\app\middleware\Hello::class,\app\middleware\Check::class]);
Pour les middlewares fréquemment utilisés, nous pouvons en définir un Alias, dans le fichier de configuration configmiddleware.php, la définition de la route définie
return [ 'hello'=>\app\middleware\Hello::class, 'check'=>\app\middleware\Check::class, ];
peut être modifiée en :
Route::group(function(){ Route::get('hello/:name','index/hello'); //... })->middleware(['hello','check']);
prend en charge la définition d'alias pour un groupe de middlewares.
return [ 'test'=>[\app\middleware\Hello::class,\app\middleware\Check::class], ];
la définition de la route peut être modifié Le middleware
Route::group(function(){ Route::get('hello/:name','index/hello'); //... })->middleware('test');
prend en charge la transmission d'un paramètre. Le middleware est défini comme suit :
<?php namespace app\middleware; class Hello { public function handle($request, \Closure $next, string $name = '') { echo 'Hello'. $name . '<br/>'; return $next($request); } }
Vous pouvez passer le paramètre name dans le deuxième paramètre du middleware de routage sauf
Route::get('hello/:name','index/hello') ->middleware('hello', 'middleware');
En plus de prendre en charge les paramètres, vous pouvez utiliser l'injection de dépendances dans la méthode handle du middleware.
Middleware du contrôleurLe middleware du contrôleur ne prend effet que lors de l'accès à un certain contrôleur
<?php namespace app\controller; class Hello { protected $middleware = ['hello','check']; public function index() { return 'Hello,ThinkPHP!<br/>'; } }
Puisque le middleware a été défini précédemment Alias, utilisez donc l'alias définition directement ici, sinon vous devez utiliser la définition complète de l'espace de noms.
Par défaut, toute méthode d'opération par laquelle le middleware défini dans le contrôleur accède au contrôleur sera exécutée. Parfois, vous ne souhaitez pas que toutes les opérations doivent exécuter le middleware. Il existe deux façons de définir le middleware du contrôleur. . Filtrage d'exécution des fichiers.
<?php namespace app\controller; class Index { protected $middleware = [ 'hello' => ['only' => ['hello']], 'check' => ['except'=> ['hello']], ]; public function hello() { return 'Hello,ThinkPHP!<br/>'; } public function check() { return 'this action require check!<br/>'; } }
Le middleware hello ne sera exécuté que lorsque l'opération hello du contrôleur Index est exécutée, tandis que le middleware de vérification sera exécuté à l'exception de la méthode hello. Vous pouvez réellement tester l'effet spécifique.
Middleware transmettant les paramètresIl existe de nombreuses façons de transmettre des paramètres entre le middleware et le contrôleur. Une méthode simple consiste à utiliser Request pour transmettre des paramètres.
<?php namespace app\middleware; class Hello { public function handle($request, \Closure $next) { $request->hello = 'ThinkPHP'; return $next($request); } }
Le middleware transmettant les paramètres au contrôleur doit être complété dans le middleware frontal. Le contrôleur ne peut pas recevoir les paramètres transmis par le post-middleware au contrôleur.
Ensuite, vous pouvez l'utiliser directement dans la méthode du contrôleur
public function index(Request $request) { return $request->hello; // ThinkPHP }
Il existe de nombreuses vidéos
Tutoriels ThinkPHP, toutes sur le site Web PHP chinois, bienvenue pour apprendre en ligne ! Cet article est reproduit à partir de : https://www.php.cn/phpkj/thinkphp/
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!