Maison cadre php PensezPHP Que signifie le middleware thinkphp ?

Que signifie le middleware thinkphp ?

Jun 29, 2019 pm 01:31 PM
thinkphp

Que signifie le middleware thinkphp ?

À partir de la version 5.1.6+, la prise en charge du middleware est officiellement introduite.

Le middleware est principalement utilisé pour intercepter ou filtrer les requêtes HTTP des applications et effectuer les traitements métier nécessaires.

Définir le middleware

Vous pouvez générer rapidement un middleware via des instructions de ligne de commande

php think make:middleware Check
Copier après la connexion

Cette commande générera une vérification sous le répertoire application/http/middleware middleware.

<?php
namespace app\http\middleware;
class Check
{
    public function handle($request, \Closure $next)
    {
        if ($request->param(&#39;name&#39;) == &#39;think&#39;) {
            return redirect(&#39;index/think&#39;);
        }
        return $next($request);
    }
}
Copier après la connexion

La méthode d'exécution d'entrée du middleware doit être la méthode handle, et le premier paramètre est l'objet Request, et le deuxième paramètre est une fermeture.

La valeur de retour de la méthode handle du middleware doit être un objet Response.

Dans ce middleware, nous effectuons un traitement de redirection lorsque nous jugeons que le paramètre name de la requête en cours est égal à think. Dans le cas contraire, la demande sera transmise à la suite de la candidature. Pour continuer à transmettre la requête à l'application, appelez simplement la fonction de rappel $next avec $request comme argument.

Sous certaines conditions, vous pouvez utiliser le troisième paramètre pour transmettre des paramètres supplémentaires.

<?php
namespace app\http\middleware;
class Check
{
    public function handle($request, \Closure $next, $name)
    {
        if ($name == &#39;think&#39;) {
            return redirect(&#39;index/think&#39;);
        }
        return $next($request);
    }
}
Copier après la connexion

Middleware pré/post

Le fait que le middleware soit exécuté avant ou après que l'opération spécifique soit demandée dépend entièrement de la définition du middleware lui-même.

Ce qui suit est un middleware pour le pré-comportement

<?php
namespace app\http\middleware;
class Before
{
    public function handle($request, \Closure $next)
    {
        // 添加中间件执行代码
        return $next($request);
    }
}
Copier après la connexion

Ce qui suit est un middleware pour le post-comportement

<?php
namespace app\http\middleware;
class After
{
    public function handle($request, \Closure $next)
    {
$response = $next($request);
        // 添加中间件执行代码
        return $response;
    }
}
Copier après la connexion

Un exemple plus pratique, nous devons déterminer la navigation actuelle L'environnement du serveur est WeChat ou Alipay

namespace app\http\middleware;
/**
 * 访问环境检查,是否是微信或支付宝等
 */
class InAppCheck
{
    public function handle($request, \Closure $next)
    {
        if (preg_match(&#39;~micromessenger~i&#39;, $request->header(&#39;user-agent&#39;))) {
            $request->InApp = &#39;WeChat&#39;;
        } else if (preg_match(&#39;~alipay~i&#39;, $request->header(&#39;user-agent&#39;))) {
            $request->InApp = &#39;Alipay&#39;;
        }
        return $next($request);
    }
}
Copier après la connexion

Ajoutez ensuite un fichier middleware.php dans votre module version mobile

Par exemple : /path/application/mobile/middleware.php

return [
    app\http\middleware\InAppCheck::class,
];
Copier après la connexion

Ensuite, dans votre contrôleur, vous pouvez obtenir la valeur pertinente via $this->request->InApp

Enregistrer le middleware

Middleware de routage

La méthode d'enregistrement middleware la plus couramment utilisée consiste à enregistrer le middleware de routage

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(&#39;Auth&#39;);
Copier après la connexion

ou à utiliser le nom complet de la classe middleware

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(app\http\middleware\Auth::class);
Copier après la connexion

pour prendre en charge plusieurs enregistrements Middleware

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([&#39;Auth&#39;, &#39;Check&#39;]);
Copier après la connexion
Copier après la connexion

Version V5.1.7+, vous pouvez directement prédéfinir le middleware dans middleware.php dans le répertoire de configuration de l'application (en ajoutant effectivement un identifiant d'alias), par exemple :

return [
&#39;auth&#39;=>app\http\middleware\Auth::class,
    &#39;check&#39;=>app\http\middleware\Check::class
];
Copier après la connexion

Utilisez ensuite l'alias du middleware pour vous inscrire

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([&#39;Auth&#39;, &#39;Check&#39;]);
Copier après la connexion
Copier après la connexion

directement dans la route. A partir de la version V5.1.8+, vous pouvez utiliser des alias pour définir un ensemble de middleware, par exemple :

return [
&#39;check&#39;=>[
    app\http\middleware\Auth::class,
   app\http\middleware\Check::class
    ],
];
Copier après la connexion

Ensuite, utilisez directement la méthode suivante Middleware d'inscription<🎜. >

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(&#39;check&#39;);
Copier après la connexion

Prend en charge le middleware d'enregistrement pour les groupes de routage

Route::group(&#39;hello&#39;, function(){
Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;);
})->middleware(&#39;Auth&#39;);
Copier après la connexion

La version V5.1.8+ commence à prendre en charge le middleware d'enregistrement pour un certain nom de domaine

Route::domain(&#39;admin&#39;, function(){
// 注册域名下的路由规则
})->middleware(&#39;Auth&#39;);
Copier après la connexion

Si vous devez transmettre des paramètres supplémentaires pour transmettre au middleware, vous pouvez utiliser

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(&#39;Auth:admin&#39;);
Copier après la connexion

Si vous utilisez une définition constante, vous pouvez transmettre les paramètres du middleware dans le deuxième paramètre.

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(Auth::class, &#39;admin&#39;);
Copier après la connexion

Si vous devez définir plusieurs middlewares, utilisez la méthode tableau

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([Auth::class, &#39;Check&#39;]);
Copier après la connexion

pour transmettre le même paramètre supplémentaire

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([Auth::class, &#39;Check&#39;], &#39;admin&#39;);
Copier après la connexion

ou spécifiez les paramètres du middleware individuellement.

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([&#39;Auth:admin&#39;, &#39;Check:editor&#39;]);
Copier après la connexion

Utilisez des fermetures pour définir un middleware

Vous n'êtes pas obligé d'utiliser des classes de middleware Dans certaines situations simples, vous pouvez utiliser des fermetures pour définir un middleware, mais la fermeture. La fonction doit renvoyer une instance d’objet Response.

Route::group(&#39;hello&#39;, function(){
Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;);
})->middleware(function($request,\Closure $next){
    if ($request->param(&#39;name&#39;) == &#39;think&#39;) {
        return redirect(&#39;index/think&#39;);
    }
    
return $next($request);
});
Copier après la connexion

Middleware global

Vous pouvez définir le fichier middleware.php sous le répertoire de l'application, en utilisant la méthode suivante :

<?php
return [
\app\http\middleware\Auth::class,
    &#39;Check&#39;,
    &#39;Hello&#39;,
];
Copier après la connexion

Enregistrement du middleware le nom complet de la classe doit être utilisé, ou si aucun espace de noms n'est spécifié, alors apphttpmiddleware sera utilisé comme espace de noms.

L'ordre d'exécution du middleware global est l'ordre de définition. Les paramètres du middleware peuvent être transmis lors de la définition du middleware global, et deux méthodes sont prises en charge.

<?php
return [
[\app\http\middleware\Auth::class, &#39;admin&#39;],
    &#39;Check&#39;,
    &#39;Hello:thinkphp&#39;,
];
Copier après la connexion

La définition ci-dessus signifie que le paramètre admin est transmis au middleware Auth et le paramètre thinkphp est transmis au middleware Hello.

Middleware de module

À partir de la version V5.1.8+, la définition du middleware de module est prise en charge. Vous pouvez ajouter le fichier middleware.php directement sous le répertoire du module. La méthode est la suivante. La définition du middleware d'application est la même, mais elle ne prendra effet que sous ce module.

Middleware de contrôleur

À partir de la version V5.1.17+, il est pris en charge pour définir un middleware pour les contrôleurs. Tout d'abord, votre contrôleur doit hériter de la classe thinkController du système, puis définir l'attribut middleware dans le contrôleur, par exemple :

<?php
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
    protected $middleware = [&#39;Auth&#39;];
    public function index()
    {
        return &#39;index&#39;;
    }
    public function hello()
    {
        return &#39;hello&#39;;
    }
}
Copier après la connexion

Lorsque le contrôleur d'index est exécuté, le middleware Auth sera appelé. utilisation de la dénomination complète.

Si vous devez définir le fonctionnement effectif au milieu du contrôleur, vous pouvez le définir comme suit :

<?php
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
    protected $middleware = [ 
    &#39;Auth&#39; => [&#39;except&#39; => [&#39;hello&#39;] ],
        &#39;Hello&#39; => [&#39;only&#39; => [&#39;hello&#39;] ],
    ];
    public function index()
    {
        return &#39;index&#39;;
    }
    public function hello()
    {
        return &#39;hello&#39;;
    }
}
Copier après la connexion

Le middleware transmet les paramètres au contrôleur

Vous pouvez transmettre les paramètres de la requête au contrôleur (ou à d'autres endroits) par affectation d'objet, tel que

<?php
namespace app\http\middleware;
class Hello
{
    public function handle($request, \Closure $next)
    {
        $request->hello = &#39;ThinkPHP&#39;;
        
        return $next($request);
    }
}
Copier après la connexion

Notez que le nom de la variable transmis ne doit pas entrer en conflit avec la variable param.

Ensuite, vous pouvez l'utiliser directement dans la méthode du contrôleur

public function index(Request $request)
{
return $request->hello; // ThinkPHP
}
Copier après la connexion
Cet article provient de la colonne d'articles techniques du framework ThinkPHP :

http://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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Comment exécuter le projet thinkphp Comment exécuter le projet thinkphp Apr 09, 2024 pm 05:33 PM

Pour exécuter le projet ThinkPHP, vous devez : installer Composer ; utiliser Composer pour créer le projet ; entrer dans le répertoire du projet et exécuter php bin/console serve ; visiter http://localhost:8000 pour afficher la page d'accueil.

Il existe plusieurs versions de thinkphp Il existe plusieurs versions de thinkphp Apr 09, 2024 pm 06:09 PM

ThinkPHP dispose de plusieurs versions conçues pour différentes versions de PHP. Les versions majeures incluent 3.2, 5.0, 5.1 et 6.0, tandis que les versions mineures sont utilisées pour corriger les bogues et fournir de nouvelles fonctionnalités. La dernière version stable est ThinkPHP 6.0.16. Lorsque vous choisissez une version, tenez compte de la version PHP, des exigences en matière de fonctionnalités et du support de la communauté. Il est recommandé d'utiliser la dernière version stable pour de meilleures performances et une meilleure assistance.

Comment exécuter thinkphp Comment exécuter thinkphp Apr 09, 2024 pm 05:39 PM

Étapes pour exécuter ThinkPHP Framework localement : Téléchargez et décompressez ThinkPHP Framework dans un répertoire local. Créez un hôte virtuel (facultatif) pointant vers le répertoire racine ThinkPHP. Configurez les paramètres de connexion à la base de données. Démarrez le serveur Web. Initialisez l'application ThinkPHP. Accédez à l'URL de l'application ThinkPHP et exécutez-la.

Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Suggestions de développement : Comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones Nov 22, 2023 pm 12:01 PM

"Suggestions de développement : comment utiliser le framework ThinkPHP pour implémenter des tâches asynchrones" Avec le développement rapide de la technologie Internet, les applications Web ont des exigences de plus en plus élevées pour gérer un grand nombre de requêtes simultanées et une logique métier complexe. Afin d'améliorer les performances du système et l'expérience utilisateur, les développeurs envisagent souvent d'utiliser des tâches asynchrones pour effectuer certaines opérations chronophages, telles que l'envoi d'e-mails, le traitement des téléchargements de fichiers, la génération de rapports, etc. Dans le domaine de PHP, le framework ThinkPHP, en tant que framework de développement populaire, offre des moyens pratiques d'implémenter des tâches asynchrones.

Lequel est le meilleur, Laravel ou thinkphp ? Lequel est le meilleur, Laravel ou thinkphp ? Apr 09, 2024 pm 03:18 PM

Comparaison des performances des frameworks Laravel et ThinkPHP : ThinkPHP fonctionne généralement mieux que Laravel, en se concentrant sur l'optimisation et la mise en cache. Laravel fonctionne bien, mais pour les applications complexes, ThinkPHP peut être mieux adapté.

Comment installer thinkphp Comment installer thinkphp Apr 09, 2024 pm 05:42 PM

Étapes d'installation de ThinkPHP : Préparez les environnements PHP, Composer et MySQL. Créez des projets à l'aide de Composer. Installez le framework ThinkPHP et ses dépendances. Configurez la connexion à la base de données. Générez le code de l'application. Lancez l'application et visitez http://localhost:8000.

Quelles sont les performances de thinkphp ? Quelles sont les performances de thinkphp ? Apr 09, 2024 pm 05:24 PM

ThinkPHP est un framework PHP hautes performances présentant des avantages tels que le mécanisme de mise en cache, l'optimisation du code, le traitement parallèle et l'optimisation des bases de données. Les tests de performances officiels montrent qu'il peut gérer plus de 10 000 requêtes par seconde et qu'il est largement utilisé dans les sites Web à grande échelle et les systèmes d'entreprise tels que JD.com et Ctrip dans les applications réelles.

Suggestions de développement : Comment utiliser le framework ThinkPHP pour le développement d'API Suggestions de développement : Comment utiliser le framework ThinkPHP pour le développement d'API Nov 22, 2023 pm 05:18 PM

Suggestions de développement : Comment utiliser le framework ThinkPHP pour le développement d'API Avec le développement continu d'Internet, l'importance de l'API (Application Programming Interface) est devenue de plus en plus importante. L'API est un pont de communication entre différentes applications. Elle peut réaliser le partage de données, l'appel de fonctions et d'autres opérations, et offre aux développeurs une méthode de développement relativement simple et rapide. En tant qu'excellent framework de développement PHP, le framework ThinkPHP est efficace, évolutif et facile à utiliser.

See all articles