Heim PHP-Framework Laravel Laravel-Entwicklung: Wie implementiert man die API-Authentifizierung mit Laravel Passport und JWT?

Laravel-Entwicklung: Wie implementiert man die API-Authentifizierung mit Laravel Passport und JWT?

Jun 13, 2023 pm 11:41 PM
laravel jwt passport

Laravel-Entwicklung: Wie implementiert man die API-Authentifizierung mit Laravel Passport und JWT?

API-Authentifizierung (Application Programming Interface) ist eine häufige Anforderung in heutigen Internetanwendungen. Als beliebtes PHP-Framework bietet Laravel zwei Tools, Laravel Passport und JWT (JSON Web Tokens), die uns bei der Implementierung der API-Authentifizierung helfen können.

In diesem Artikel erfahren Sie, wie Sie die API-Authentifizierung mit Laravel Passport und JWT implementieren. Im folgenden Inhalt werden wir die Grundkonzepte dieser beiden Tools verstehen und erfahren, wie man sie in Laravel-Anwendungen konfiguriert und verwendet.

Was ist Laravel Passport?

Laravel Passport ist ein OAuth2-Server, der speziell für das Laravel-Framework entwickelt wurde und uns dabei helfen kann, API-Authentifizierungssysteme schnell und sicher aufzubauen. Passport bietet eine Reihe von APIs zur Durchführung des Authentifizierungsprozesses und hat intern eine Reihe von Authentifizierungsmethoden implementiert, die durch das OAuth2-Protokoll angegeben werden.

Unter diesen ist OAuth2 ein Standardprotokoll, das Proxy-Autorisierung verwendet. Die Proxy-Autorisierung ist ein Autorisierungsmechanismus, um im Namen eines Benutzers Zugriff auf Ressourcen zu erhalten. Das OAuth2-Protokoll stellt „Zugriffstokens“ für Anwendungen von Drittanbietern aus, um im Namen des Benutzers auf geschützte Ressourcen zuzugreifen. Daher spielt Passport tatsächlich die Rolle des OAuth2-Authentifizierungsservers in Laravel-Anwendungen.

Was ist JWT?

JWT (JSON Web Tokens) ist ein offener Standard (RFC 7519) für die Authentifizierung und Autorisierung in verteilten Netzwerkumgebungen. JWT wird häufig verwendet, um authentifizierte Benutzeridentitätsinformationen und Ansprüche zwischen Clients und Servern weiterzugeben. JWT besteht aus drei Teilen: Header, Payload und Signatur.

Normalerweise enthält der Header den JWT-Typ und den verwendeten Verschlüsselungsalgorithmus, die Nutzlast enthält Informationen und Ansprüche zur Benutzeridentität und die Signatur wird zur Überprüfung der Authentizität des JWT verwendet. Wenn JWT zur Authentifizierung verwendet wird, ermittelt der Server die Identität des Benutzers, indem er die Informationen im JWT entschlüsselt und so eine API-Authentifizierung erreicht.

Laravel Passport und JWT konfigurieren

Bevor wir Laravel Passport und JWT für die API-Authentifizierung verwenden, müssen wir es zuerst in der Laravel-Anwendung konfigurieren. Im Folgenden sind die spezifischen Konfigurationsschritte aufgeführt:

Schritt 1: Laravel Passport und tymon/jwt-auth installieren

Verwenden Sie Composer, um Laravel Passport und tymon/jwt-auth im Befehlszeilentool zu installieren:

composer require laravel/passport
composer require tymon/jwt-auth
Nach dem Login kopieren

Schritt 2: Laravel konfigurieren Passport

Fügen Sie in der Datei config/app.php den folgenden Dienstanbieter hinzu:

'providers' => [
    ...
    LaravelPassportPassportServiceProvider::class,
],
Nach dem Login kopieren

Führen Sie dann den folgenden Befehl aus, um die Datentabelle von Passport zu erstellen:

php artisan migrate
Nach dem Login kopieren

Für Passports Standardauthentifizierungsmethode „Password Grant“ fügen wir ihn hinzu das Benutzermodell „PassportHasApiTokens“ (Passports Standard-Benutzerauthentifizierungsmerkmal). Öffnen Sie die Datei User.php und fügen Sie den folgenden Inhalt hinzu:

use LaravelPassportHasApiTokens;

class User extends Authenticatable
{
    use HasApiTokens, Notifiable;
    ...
}
Nach dem Login kopieren

Schritt 3: JWT konfigurieren

Fügen Sie zunächst in der Datei config/app.php den JWTServiceProvider hinzu:

'providers' => [
    ...
    TymonJWTAuthProvidersLaravelServiceProvider::class,
],
Nach dem Login kopieren

Führen Sie dann den folgenden Befehl aus, um das Geheimnis zu generieren Für JWT erforderlicher Schlüssel:

php artisan jwt:secret
Nach dem Login kopieren

Fügen Sie in der Datei config/auth.php die JWT-Guard-Konfiguration hinzu (verwenden Sie jwt als Guard-Option) und setzen Sie den Standardauthentifizierungstreiber auf „jwt“:

'guards' => [
    ...
    'jwt' => [
        'driver' => 'jwt',
        'provider' => 'users'
    ],
],
...
'defaults' => [
    'guard' => 'jwt',
    ...
],
Nach dem Login kopieren

In der Datei config/auth .php-Datei, fügen Sie die Benutzerkonfiguration des JWT-Benutzeranbieters hinzu (Anweisungen zur Verwendung des Eloquent-Modells):

'providers' => [
    ...
    'users' => [
        'driver' => 'eloquent',
        'model' => AppModelsUser::class
    ]
],
Nach dem Login kopieren

Verwenden von Laravel Passport und JWT für die API-Authentifizierung

Nachdem die Vorbereitung abgeschlossen ist, können wir die API-Authentifizierung problemlos mit Laravel Passport und JWT implementieren. Das Folgende ist der spezifische Vorgang:

Schritt 1: API-Routing registrieren

Registrieren Sie zunächst die API-Route in der Datei „routes/api.php“. Beispielsweise definieren wir eine GET-Route zum Abrufen von Benutzerinformationen:

Route::middleware('auth:api')->get('/user', function (Request $request) {
    return $request->user();
});
Nach dem Login kopieren

Laravels Middleware auth:api wird hier verwendet, um sicherzustellen, dass Anfragen von authentifizierten Benutzern weitergeleitet werden können. Mit der Routing-Middleware fügen wir diesen Schritt der Authentifizierung zur Route hinzu.

Schritt 2: Zugriffstoken erstellen

Benutzer müssen über das Zugriffstoken auf die API zugreifen. Wir müssen ein Passwort verwenden, um das Zugriffstoken zu autorisieren. Die spezifischen Implementierungsschritte sind wie folgt:

Sie müssen zuerst eine Route definieren, um den vom Benutzer bereitgestellten Benutzernamen und das Passwort zu erhalten:

Route::post('/login', function (Request $request) {
    $http = new GuzzleHttpClient;

    $response = $http->post('http://your-app.com/oauth/token', [
        'form_params' => [
            'grant_type' => 'password',
            'client_id' => 'client-id',
            'client_secret' => 'client-secret',
            'username' => $request->username,
            'password' => $request->password,
            'scope' => '',
        ],
    ]);

    return json_decode((string) $response->getBody(), true);
});
Nach dem Login kopieren

Im obigen Code verwenden wir Der GuzzleHttp-Client sendet eine POST-Anfrage und erhält ein Zugriffstoken. Unter diesen muss grant_type „password“ sein, client_id und client_secret müssen jeweils der in Laravel Passport verwendeten ID und dem Secret entsprechen. Nachdem die Anfrage erfolgreich war, wird eine JSON-Antwort zurückgegeben, die das Zugriffstoken „access_token“ des Benutzers für den Zugriff auf die API enthält.

Schritt 3: Initiieren Sie eine API-Anfrage

Wir können das erhaltene Token access_token verwenden, um eine Anfrage an die API zu senden, die Identität des Benutzers zu überprüfen und geschützte Ressourcen zu erhalten. Wenn Sie eine Anfrage an die API stellen, müssen Sie das Autorisierungs-Schlüssel-Wert-Paar im Header hinzufügen, dessen Wert „Bearer access_token“ ist. Beispiel:

$accessToken = 'your-access-token';
$response = $http->withHeaders([
    'Authorization' => 'Bearer ' . $accessToken
])->get('http://your-app.com/api/user');
Nach dem Login kopieren

Wenn die Anfrage erfolgreich ist, gibt die API die Benutzerinformationen zurück.

Fazit

In Laravel-Anwendungen bietet Laravel Passport ein leistungsstarkes OAuth2-Authentifizierungsprotokoll und eine API-Authentifizierungsfunktion, und JWT ist eine sichere und bequeme Authentifizierungsmethode. In der tatsächlichen Entwicklung können wir Laravel Passport und JWT in Kombination verwenden, um die Sicherheit und Zuverlässigkeit der API zu verbessern und Benutzerdaten vor Diebstahl oder Manipulation durch böswillige Angreifer zu schützen.

Das obige ist der detaillierte Inhalt vonLaravel-Entwicklung: Wie implementiert man die API-Authentifizierung mit Laravel Passport und JWT?. 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)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 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)

Wie verwende ich objektrelationales Mapping (ORM) in PHP, um Datenbankoperationen zu vereinfachen? Wie verwende ich objektrelationales Mapping (ORM) in PHP, um Datenbankoperationen zu vereinfachen? May 07, 2024 am 08:39 AM

Datenbankoperationen in PHP werden durch ORM vereinfacht, das Objekte in relationalen Datenbanken abbildet. EloquentORM in Laravel ermöglicht Ihnen die Interaktion mit der Datenbank mithilfe einer objektorientierten Syntax. Sie können ORM verwenden, indem Sie Modellklassen definieren, Eloquent-Methoden verwenden oder in der Praxis ein Blog-System erstellen.

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.

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?

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

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.

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.

PHP-Code-Unit-Tests und Integrationstests PHP-Code-Unit-Tests und Integrationstests May 07, 2024 am 08:00 AM

Leitfaden zum Testen von PHP-Einheiten und -Integrationen Unit-Tests: Konzentrieren Sie sich auf eine einzelne Code- oder Funktionseinheit und verwenden Sie PHPUnit, um Testfallklassen zur Überprüfung zu erstellen. Integrationstests: Achten Sie darauf, wie mehrere Codeeinheiten zusammenarbeiten, und verwenden Sie die Methoden setUp() und TearDown() von PHPUnit, um die Testumgebung einzurichten und zu bereinigen. Praktischer Fall: Verwenden Sie PHPUnit, um Unit- und Integrationstests in Laravel-Anwendungen durchzuführen, einschließlich der Erstellung von Datenbanken, dem Starten von Servern und dem Schreiben von Testcode.

Fragen und Antworten zum Design der PHP-Microservice-Architektur für Unternehmensanwendungen Fragen und Antworten zum Design der PHP-Microservice-Architektur für Unternehmensanwendungen May 07, 2024 am 09:36 AM

Die Microservice-Architektur nutzt PHP-Frameworks (wie Symfony und Laravel) zur Implementierung von Microservices und folgt RESTful-Prinzipien und Standarddatenformaten zum Entwerfen von APIs. Microservices kommunizieren über Nachrichtenwarteschlangen, HTTP-Anfragen oder gRPC und nutzen Tools wie Prometheus und ELKStack zur Überwachung und Fehlerbehebung.

See all articles