Heim PHP-Framework Laravel So verwenden Sie Middleware für die API-Authentifizierung in Laravel

So verwenden Sie Middleware für die API-Authentifizierung in Laravel

Nov 02, 2023 am 08:43 AM
laravel 中间件 api认证

So verwenden Sie Middleware für die API-Authentifizierung in Laravel

So verwenden Sie Middleware für die API-Authentifizierung in Laravel

Middleware (Middleware) spielt eine sehr wichtige Rolle im Laravel-Framework. Sie kann verwendet werden, um Codelogik auszuführen, bevor und nachdem die HTTP-Anfrage die Anwendung erreicht. Bei der Entwicklung von API-Anwendungen müssen wir in der Regel Benutzer authentifizieren, um sicherzustellen, dass nur legitime Benutzer auf sensible Daten zugreifen oder die API bedienen können.

In diesem Artikel wird die Verwendung von Middleware für die API-Authentifizierung vorgestellt. Das konkrete Beispiel basiert auf dem Laravel-Framework. Wir werden ein grundlegendes Token-Authentifizierungsschema implementieren, um unsere API-Schnittstelle zu schützen.

Zuerst müssen wir eine Middleware erstellen, um das Token zu überprüfen. Führen Sie den folgenden Befehl aus, um eine Middleware mit dem Namen „ApiAuthMiddleware“ zu erstellen:

php artisan make:middleware ApiAuthMiddleware
Nach dem Login kopieren

Nach erfolgreichem Vorgang sehen Sie die generierte Middleware-Datei im Verzeichnis app/Http/Middleware.

Als nächstes implementieren Sie die Methode „authenticate()“ in ApiAuthMiddleware, die überprüft, ob das Token in der Anfrage gültig ist:

<?php

namespace AppHttpMiddleware;

use Closure;
use IlluminateHttpRequest;

class ApiAuthMiddleware
{
    public function handle(Request $request, Closure $next)
    {
        $token = $request->header('Authorization');

        if (!$token) {
            return response()->json(['message' => 'Token not provided'], 401);
        }

        // 这里可根据具体业务逻辑来验证Token的有效性,比如查询数据库或使用第三方服务进行验证

        if ($token !== 'valid_token') {
            return response()->json(['message' => 'Invalid Token'], 401);
        }

        // Token验证通过,继续执行请求
        return $next($request);
    }
}
Nach dem Login kopieren

Im obigen Code erhalten wir das Token zuerst aus dem Anfrageheader und dann basierend auf dem spezifischen Unternehmen Logik Überprüfen Sie die Gültigkeit des Tokens. Wenn das Token nicht vorhanden ist oder die Validierung fehlschlägt, wird der Fehler 401 Unauthorized zurückgegeben. Andernfalls übergeben wir die Anforderung an die nächste Middleware oder den nächsten Routenhandler.

Als nächstes müssen wir ApiAuthMiddleware als globale Middleware registrieren, damit die Token-Authentifizierung bei jeder API-Anfrage erfolgt. Fügen Sie den folgenden Code im Array $routeMiddleware der Datei app/Http/Kernel.php hinzu:

protected $routeMiddleware = [
    // ...
    'api.auth' => AppHttpMiddlewareApiAuthMiddleware::class,
];
Nach dem Login kopieren

Im obigen Code registrieren wir ApiAuthMiddleware als Middleware-Alias ​​„api.auth“.

Jetzt können wir die Middleware „api.auth“ in Routen oder Controller-Methoden verwenden, die eine API-Authentifizierung erfordern. Hier ist ein Beispiel:

<?php

namespace AppHttpControllers;

use IlluminateHttpRequest;

class ApiController extends Controller
{
    public function __construct()
    {
        $this->middleware('api.auth');
    }

    public function getData(Request $request)
    {
        return response()->json(['message' => 'Authorized'], 200);
    }
}
Nach dem Login kopieren

Im obigen Code verwenden wir die Methode middleware() im Konstruktor des ApiControllers, um die Middleware „api.auth“ auf alle Methoden dieses Controllers anzuwenden. In der Methode getData() geben wir eine einfache Autorisierungserfolgsmeldung zurück.

Wenn wir nun eine GET-Anfrage an „/api/data“ initiieren, wird die Anfrage zunächst von ApiAuthMiddleware authentifiziert. Wenn das Token in der Anfrage gültig ist, wird eine erfolgreiche Autorisierungsmeldung zurückgegeben; andernfalls wird der Fehler 401 Unauthorized zurückgegeben.

Zusammenfassung

Durch die Verwendung von Middleware für die API-Authentifizierung können wir unsere API-Schnittstelle einfach schützen und nur legitimen Benutzern den Zugriff darauf ermöglichen. In diesem Artikel haben wir gelernt, wie man eine benutzerdefinierte Middleware erstellt und verwendet, um die Gültigkeit eines Tokens zu überprüfen und es als globale Middleware zu registrieren.

Natürlich ist dies nur ein einfaches Beispiel. Sie können die Authentifizierungslogik entsprechend Ihren Geschäftsanforderungen erweitern und anpassen. Gleichzeitig können Sie auch andere Arten von Authentifizierungsmethoden wie OAuth, JWT usw. verwenden. Die leistungsstarken Middleware-Funktionen des Laravel-Frameworks bieten eine flexible und leicht erweiterbare Lösung für die API-Authentifizierung.

Das obige ist der detaillierte Inhalt vonSo verwenden Sie Middleware für die API-Authentifizierung in Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Vergleich der neuesten Versionen von Laravel und CodeIgniter Vergleich der neuesten Versionen von Laravel und CodeIgniter Jun 05, 2024 pm 05:29 PM

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Wie vergleichen sich die Datenverarbeitungsfunktionen in Laravel und CodeIgniter? Jun 01, 2024 pm 01:34 PM

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Was ist einsteigerfreundlicher: Laravel oder CodeIgniter? Jun 05, 2024 pm 07:50 PM

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für große Projekte? Jun 04, 2024 am 09:09 AM

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Laravel – Handwerkerbefehle Laravel – Handwerkerbefehle Aug 27, 2024 am 10:51 AM

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Laravel vs CodeIgniter: Welches Framework ist besser für kleine Projekte? Jun 04, 2024 pm 05:29 PM

Für kleine Projekte eignet sich Laravel, für größere Projekte, die starke Funktionalität und Sicherheit erfordern. CodeIgniter eignet sich für sehr kleine Projekte, die geringes Gewicht und Benutzerfreundlichkeit erfordern.

Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Welche ist die bessere Template-Engine, Laravel oder CodeIgniter? Jun 03, 2024 am 11:30 AM

Vergleichen Sie Laravel's Blade und die Twig-Vorlagen-Engine von CodeIgniter und wählen Sie je nach Projektanforderungen und persönlichen Vorlieben: Blade basiert auf der MVC-Syntax, die eine gute Codeorganisation und Vorlagenvererbung fördert. Twig ist eine Bibliothek eines Drittanbieters, die flexible Syntax, leistungsstarke Filter, erweiterten Support und eine Sicherheits-Sandbox bietet.

Verwalten der Wiederverwendung von Middleware und der gemeinsamen Nutzung von Ressourcen im Java-Framework Verwalten der Wiederverwendung von Middleware und der gemeinsamen Nutzung von Ressourcen im Java-Framework Jun 01, 2024 pm 03:10 PM

Das Java-Framework unterstützt die Wiederverwendung von Middleware und die gemeinsame Nutzung von Ressourcen, einschließlich der folgenden Strategien: Verwaltung vorab eingerichteter Middleware-Verbindungen über Verbindungspools. Nutzen Sie den Thread-lokalen Speicher, um Middleware-Verbindungen mit dem aktuellen Thread zu verknüpfen. Verwenden Sie einen Thread-Pool, um wiederverwendbare Threads zu verwalten. Speichern Sie Kopien häufig aufgerufener Daten über lokale oder verteilte Caches.

See all articles