Heim  >  Artikel  >  PHP-Framework  >  Was ist Thinkphp-Middleware?

Was ist Thinkphp-Middleware?

藏色散人
藏色散人Original
2019-07-04 13:30:347734Durchsuche

ThinkPHP wurde geboren, um die Anwendungsentwicklung auf Unternehmensebene und die agile WEB-Anwendungsentwicklung zu vereinfachen. Es wurde erstmals Anfang 2006 geboren, am Neujahrstag 2007 offiziell in ThinkPHP umbenannt und im Rahmen der Apache2-Open-Source-Vereinbarung veröffentlicht. ThinkPHP hält sich seit seiner Gründung an das einfache und praktische Designprinzip und legt dabei den Schwerpunkt auf eine hervorragende Leistung und minimalen Code. Und es verfügt über viele originelle Funktionen und Features. Unter aktiver Beteiligung des Community-Teams wird es hinsichtlich Benutzerfreundlichkeit, Skalierbarkeit und Leistung kontinuierlich optimiert und verbessert.

Was ist Thinkphp-Middleware?

Was ist Thinkphp-Middleware?

Ab Version 5.1.6+ wird die Middleware-Unterstützung offiziell eingeführt.

Middleware wird hauptsächlich verwendet, um HTTP-Anfragen von Anwendungen abzufangen oder zu filtern und die notwendige Geschäftsverarbeitung durchzuführen.

Middleware definieren

Sie können Middleware schnell über Befehlszeilenanweisungen generieren

php think make:middleware Check

Dieser Befehl generiert einen Check im Verzeichnis 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);
    }
}

Die Eintragsausführungsmethode der Middleware muss die Handle-Methode sein, und der erste Parameter ist das Request-Objekt und der zweite Parameter ist ein Abschluss.

Der Rückgabewert der Middleware-Handle-Methode muss ein Response-Objekt sein.

In dieser Middleware führen wir eine Umleitungsverarbeitung durch, wenn wir feststellen, dass der Namensparameter der aktuellen Anforderung gleich ist. Andernfalls wird die Anfrage an die Bewerbung weitergeleitet. Um die Anfrage weiterhin an die Anwendung weiterzuleiten, rufen Sie einfach die Rückruffunktion $next mit $request als Argument auf.

Unter bestimmten Voraussetzungen können Sie über den dritten Parameter weitere Parameter übergeben.

<?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);
    }
}

Pre/Post-Middleware

Ob die Middleware vor oder nach der Anforderung des spezifischen Vorgangs ausgeführt wird, hängt vollständig von der Definition der Middleware selbst ab.

Das Folgende ist eine Middleware für das Vorverhalten

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

Das Folgende ist eine Middleware für das Nachverhalten

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

Ein praktischeres Beispiel: Wir müssen das aktuelle Browsing bestimmen Die Serverumgebung ist WeChat oder 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);
    }
}

Fügen Sie dann eine middleware.php-Datei in Ihrem Mobilversionsmodul hinzu

Zum Beispiel: /path/application/mobile/middleware.php

return [
    app\http\middleware\InAppCheck::class,
];

Dann können Sie in Ihrem Controller den relevanten Wert über $this->request->InApp

Middleware registrieren

Routing-Middleware

Die am häufigsten verwendete Middleware-Registrierungsmethode ist die Registrierung der Routing-Middleware

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(&#39;Auth&#39;);

oder die Verwendung des vollständigen Middleware-Klassennamens

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(app\http\middleware\Auth::class);

, um mehrere Registrierungen der Middleware

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([&#39;Auth&#39;, &#39;Check&#39;]);
V5.1.7+ Version, Sie können die Middleware direkt in middleware.php im Anwendungskonfigurationsverzeichnis vordefinieren (und tatsächlich eine Alias-ID hinzufügen), zum Beispiel:

return [
&#39;auth&#39;=>app\http\middleware\Auth::class,
    &#39;check&#39;=>app\http\middleware\Check::class
];

Dann verwenden Sie den Middleware-Alias, um

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([&#39;Auth&#39;, &#39;Check&#39;]);

direkt in der Route. Ab Version V5.1.8+ können Sie Aliase verwenden, um eine Reihe von Middleware zu definieren, zum Beispiel:

return [
&#39;check&#39;=>[
    app\http\middleware\Auth::class,
   app\http\middleware\Check::class
    ],
];

Verwenden Sie dann die folgende Methode direkt Registrierungs-Middleware

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(&#39;check&#39;);

Unterstützt Registrierungs-Middleware für Routinggruppen

Route::group(&#39;hello&#39;, function(){
Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;);
})->middleware(&#39;Auth&#39;);

Version 5.1.8+ beginnt mit der Unterstützung der Registrierungs-Middleware für einen bestimmten Domänennamen

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

Wenn Sie zusätzliche Parameter übergeben müssen Für Middleware können Sie

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(&#39;Auth:admin&#39;);

verwenden. Wenn Sie eine Konstantendefinition verwenden, können Sie die Middleware-Parameter im zweiten Parameter übergeben.

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware(Auth::class, &#39;admin&#39;);

Wenn Sie mehrere Middlewares definieren müssen, verwenden Sie die Array-Methode

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([Auth::class, &#39;Check&#39;]);

, um denselben zusätzlichen Parameter

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([Auth::class, &#39;Check&#39;], &#39;admin&#39;);

zu übergeben, oder geben Sie die Middleware-Parameter einzeln an.

Route::rule(&#39;hello/:name&#39;,&#39;hello&#39;)
->middleware([&#39;Auth:admin&#39;, &#39;Check:editor&#39;]);

Verschluss verwenden, um Middleware zu definieren

In einigen einfachen Situationen können Sie Verschlüsse verwenden, um Middleware zu definieren, aber den Abschluss Die Funktion muss eine Response-Objektinstanz zurückgeben.

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);
});

Globale Middleware

Sie können die Datei middleware.php im Anwendungsverzeichnis mit der folgenden Methode definieren:

<?php
return [
\app\http\middleware\Auth::class,
    &#39;Check&#39;,
    &#39;Hello&#39;,
];

Registrierung der Middleware Es sollte der vollständige Klassenname verwendet werden. Wenn kein Namespace angegeben ist, wird apphttpmiddleware als Namespace verwendet.

Die Ausführungsreihenfolge globaler Middleware ist die Definitionsreihenfolge. Beim Definieren globaler Middleware können Middleware-Parameter übergeben werden. Es werden zwei Methoden unterstützt.

<?php
return [
[\app\http\middleware\Auth::class, &#39;admin&#39;],
    &#39;Check&#39;,
    &#39;Hello:thinkphp&#39;,
];

Die obige Definition bedeutet, dass der Admin-Parameter an die Auth-Middleware und der thinkphp-Parameter an die Hello-Middleware übergeben wird.

Modul-Middleware

Ab Version V5.1.8+ wird die Modul-Middleware-Definition direkt im Modulverzeichnis hinzugefügt Die Methode lautet wie folgt: Die Definition der Anwendungs-Middleware ist dieselbe, wird jedoch nur unter diesem Modul wirksam.

Controller-Middleware

Ab V5.1.17+ wird die Definition von Middleware für Controller unterstützt. Zuerst muss Ihr Controller die thinkController-Klasse des Systems erben und dann das Middleware-Attribut im Controller definieren, zum Beispiel:

<?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;;
    }
}

Wenn der Index-Controller ausgeführt wird, wird die Auth-Middleware aufgerufen. Es unterstützt auch Verwendung einer vollständigen Benennung.

Wenn Sie den effektiven Betrieb in der Mitte des Controllers festlegen müssen, können Sie ihn wie folgt definieren:

<?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;;
    }
}

Die Middleware übergibt Parameter an den Controller

Sie können die Anforderung „Pass-Parameter“ durch Objektzuweisung an den Controller (oder andere Stellen) übergeben, z. B.

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

. Beachten Sie, dass der übergebene Variablenname nicht mit der Parametervariable in Konflikt stehen sollte.

Dann können Sie es direkt in der Controller-Methode verwenden

public function index(Request $request)
{
return $request->hello; // ThinkPHP
}

本文来自ThinkPHP框架技术文章栏目:http://www.php.cn/phpkj/thinkphp/

Das obige ist der detaillierte Inhalt vonWas ist Thinkphp-Middleware?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn