


Detaillierte Einführung in den Prozess, die Konfiguration und die Verwendung von Laravel Passport
Laravel Passport ist eine vollständige OAuth2-Serverimplementierung unter dem Laravel-Framework. Sie ermöglicht die Authentifizierung und Autorisierung von Benutzeridentitäten über APIs, sodass auf API-Dienste zugegriffen werden kann, ohne dass Benutzeranmeldeinformationen offengelegt werden, was die Arbeitsbelastung des Clients erheblich verringert und die Anwendungssicherheit verbessert .
Das OAuth2-Protokoll hinter Laravel Passport ist ein Industriestandard, sodass Sie die OAuth2-Authentifizierung und -Autorisierung problemlos in andere Sprachen und Frameworks integrieren können, indem Sie dieselben Tools und Prozesse verwenden. Im Folgenden werden in diesem Artikel der Prozess, die Konfiguration und die Verwendung von Laravel Passport im Detail vorgestellt.
Passport installieren
Bevor Sie Laravel Passport verwenden, müssen Sie es installieren. Wir können den Composer-Befehl verwenden, um Passport zu installieren. Der Befehl lautet wie folgt:
composer require laravel/passport
Enable Passport
Nach der Installation von Laravel Passport müssen Sie seinen Dienstanbieter zum Provider-Array in der Datei config/app.php hinzufügen Öffnen Sie die Datei, suchen Sie nach Anbietern und fügen Sie den Dienstanbieter von Laravel Passport hinzu, wie unten gezeigt:
'providers' => [ // Other Service Providers... Laravel\Passport\PassportServiceProvider::class, ],
Datenbanktabelle erstellen
Bevor Sie Laravel Passport verwenden, müssen Sie auch die für Passport erforderliche Datenbanktabelle erstellen Befehl zum Generieren der Migrationsdatei:
php artisan migrate
Nach der Ausführung des obigen Befehls erstellt Laravel Passport mehrere neue Tabellen in Ihrer Datenbank, um Daten wie OAuth2-Client, Zugriffstoken und Aktualisierungstoken zu speichern.
Veröffentlichen Sie die Konfigurationsdatei
Führen Sie den folgenden Handwerkerbefehl aus, um die Passport-Konfigurationsdatei im Konfigurationsverzeichnis des Laravel-Projekts zu veröffentlichen:
php artisan vendor:publish --tag=passport-config
Erstellen Sie den Schlüssel
An diesem Punkt haben wir die für die Verwendung von Laravel Passport erforderlichen Voraussetzungen erfüllt Zustand. Als nächstes müssen wir den folgenden Handwerkerbefehl verwenden, um Verschlüsselungsschlüssel zu generieren:
php artisan passport:keys
Der obige Befehl generiert Verschlüsselungsschlüssel zum Signieren von Daten wie Cookies und Zugriffstoken.
Passport konfigurieren
Nach Abschluss der oben genannten Schritte müssen wir als Nächstes Passport konfigurieren, damit es ausgeführt werden kann. Ändern Sie in der Konfigurationsdatei config/auth.php den Treiber des API-Treibers in Passport und legen Sie die Wächter und Anbieter wie folgt fest:
'guards' => [ 'web' => [ 'driver' => 'session', 'provider' => 'users', ], 'api' => [ 'driver' => 'passport', 'provider' => 'users', ], ],
Konfigurieren Sie die Anbieter in derselben Datei wie folgt:
'providers' => [ 'users' => [ 'driver' => 'eloquent', 'model' => App\Models\User::class, ], ],
Einmal konfiguriert Sobald die Datei ist abgeschlossen, die API-Zertifizierung ist fertig.
Route erstellen
Als nächstes müssen wir eine API-Route in der App/HTTP-Routing-Datei erstellen, wie unten gezeigt:
Route::middleware('auth:api')->get('/user', function (Request $request) { return $request->user(); });
Im obigen Routing-Beispiel ist die auth:api-Middleware definiert, um zu überprüfen, ob die Anfrage von Authenticated stammt Wenn es sich nicht um authentifizierte Benutzer handelt, wird der Statuscode 401 zurückgegeben, wenn die Überprüfung fehlschlägt.
Client erstellen
Da wir nun die Anwendungskonfiguration und die API-Routing-Einstellungen abgeschlossen haben, müssen wir den API-Client erstellen. In Laravel Passport wird der handwerkliche Befehl „passport:client“ zum Erstellen eines neuen OAuth2-Clients bereitgestellt. Führen Sie den Befehl wie unten gezeigt aus:
php artisan passport:client --client
Nach der Ausführung des Befehls müssen wir den Clientnamen und den Autorisierungsumleitungs-URI wie unten gezeigt eingeben:
php artisan passport:client --client Which user ID should the client be assigned to? [0]: > 1 What should we name the client? > Test Where should we redirect the request after authorization? > http://example.com/callback
Der obige Befehl erstellt einen neuen OAuth2-Client zur Anwendung auf diesen. Die API des Programms sendet die Anfrage. Wir erhalten eine Client-ID und ein Client-Geheimnis, die wir in nachfolgenden API-Anfragen verwenden können.
Autorisierung erhalten
Der Client wurde erstellt und hat den Autorisierungs-Umleitungs-URI erhalten. Jetzt müssen wir eine Anfrage an den URI senden, um eine Autorisierung zu erhalten. Anschließend generiert Passport ein Zugriffstoken für den Client und sendet es an den Client zurück. Verwenden Sie die unten gezeigte URL und ersetzen Sie die Client-ID und den Umleitungs-URI:
http://your-app.com/oauth/authorize?client_id={client-id}&redirect_uri={redirect-uri} &response_type=code&scope=
Nach Eingabe der URL wird der unten gezeigte OAuth2-Autorisierungsbildschirm angezeigt:
Nach dem Klicken auf die Schaltfläche „Autorisieren“ erfolgt die Autorisierung und die Umleitung zum Umleitungs-URI erfolgt.
Zugriffstoken erhalten
Jetzt haben wir die Autorisierung erhalten und dem Kunden wurde Zugriff auf die API gewährt. Wir müssen den OAuth2-Autorisierungscode verwenden, um den Client-Schlüssel gegen das Zugriffstoken auszutauschen. Wir können den Curl-Befehl wie unten gezeigt verwenden, um das Zugriffstoken vom API-Autorisierungsserver zu erhalten:
$ curl -X POST -H "Accept: application/json" -F "client_id={client-id}" -F "client_secret={client-secret}" -F "grant_type=authorization_code" -F "code={code}" -F "redirect_uri={redirect-uri}" http://your-app.com/oauth/token
Nachdem Sie den obigen Befehl ausgeführt haben, erhalten Sie das folgende JSON-Objekt, das Informationen wie „access_token“ und „refresh_token“ enthält:
{ "token_type": "Bearer", "expires_in": 86400, "access_token": "{access-token}", "refresh_token": "{refresh-token}", }
Zugriffstoken für API-Anfragen verwenden
Da wir nun das Zugriffstoken erhalten haben, können wir das Zugriffstoken verwenden, um Anfragen mit der API zu stellen. Wir müssen den Authorization-Header zum API-Anforderungsheader hinzufügen und das Bearer-Authentifizierungsschema einrichten, um das Zugriffstoken als Token-Inhalt zu verwenden, wie unten gezeigt:
$client = new \GuzzleHttp\Client(); $response = $client->request('GET', 'http://your-app.com/api/user', [ 'headers' => [ 'Authorization' => 'Bearer '.$accessToken, 'Accept' => 'application/json', ], ]);
Im obigen Code verwenden wir das Zugriffstoken als Bearer-TOKEN Das Format wird zur Überprüfung an den API-Server übermittelt. Nach Erfolg wird das API-Antwortergebnis abgerufen.
Zusammenfassung
In diesem Artikel haben wir über den Prozess, die Konfiguration und die Verwendung von Laravel Passport gesprochen. Mit Laravel Passport können wir API-Anwendungen schnell eine sichere Authentifizierung und Autorisierung hinzufügen und gleichzeitig das OAuth2-Protokoll unterstützen und mit Anwendungen interagieren, die die OAuth2-Autorisierung in anderen Programmiersprachen und Frameworks implementieren, sodass Entwickler schnell Sicherheit aufbauen können. Verwenden Sie API-Anwendungen.
Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in den Prozess, die Konfiguration und die Verwendung von Laravel Passport. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Sowohl Django als auch Laravel sind Full-Stack-Frameworks. Django eignet sich für Python -Entwickler und komplexe Geschäftslogik, während Laravel für PHP -Entwickler und elegante Syntax geeignet ist. 1.Django basiert auf Python und folgt der "batteriebetriebenen" Philosophie, die für schnelle Entwicklung und hohe Parallelität geeignet ist. 2. Laravel basiert auf PHP, der die Entwicklererfahrung betont und für kleine bis mittlere Projekte geeignet ist.

Wie spielt Laravel eine Rolle in der Backend -Logik? Es vereinfacht und verbessert die Backend -Entwicklung durch Routing -Systeme, eloquentorm, Authentifizierung und Autorisierung, Ereignis und Zuhörer sowie Leistungsoptimierung. 1. Das Routing -System ermöglicht die Definition der URL -Struktur und die Anforderungsverarbeitungslogik. 2.Loquentorm vereinfacht die Datenbankinteraktion. 3. Das Authentifizierungs- und Autorisierungssystem ist für die Benutzerverwaltung geeignet. 4. Die Ereignis und der Hörer implementieren locker gekoppelte Codestruktur. 5. Leistungsoptimierung verbessert die Anwendungseffizienz durch Zwischenspeicherung und Warteschlange.

PHP und Laravel sind nicht direkt vergleichbar, da Laravel ein PHP-basierter Framework ist. 1.PHP ist für kleine Projekte oder schnelle Prototypen geeignet, da es einfach und direkt ist. 2. Laravel ist für große Projekte oder effiziente Entwicklung geeignet, da es umfangreiche Funktionen und Werkzeuge bietet, aber eine steile Lernkurve aufweist und möglicherweise nicht so gut ist wie reines PHP.

LaravelisabackendFrameworkBuiltonPhp, entworfene WebApplicationDevelopment.itfocuseSonserver-Sidelogic, DatabaSemanagement und Applicationsstruktur und CanBeintegratedWithFrontendTechnologies-ähnlich.

Laravel ist ein PHP -Framework zum einfachen Aufbau von Webanwendungen. Es bietet eine Reihe leistungsstarker Funktionen, darunter: Installation: Installieren Sie die Laravel CLI weltweit mit Komponisten und erstellen Sie Anwendungen im Projektverzeichnis. Routing: Definieren Sie die Beziehung zwischen der URL und dem Handler in Routen/Web.php. Ansicht: Erstellen Sie eine Ansicht in Ressourcen/Ansichten, um die Benutzeroberfläche der Anwendung zu rendern. Datenbankintegration: Bietet eine Out-of-the-Box-Integration in Datenbanken wie MySQL und verwendet Migration, um Tabellen zu erstellen und zu ändern. Modell und Controller: Das Modell repräsentiert die Datenbankentität und die Controller -Prozesse HTTP -Anforderungen.

Das Laravel -Entwicklungsprojekt wurde aufgrund seiner Flexibilität und Kraft ausgewählt, um den Bedürfnissen unterschiedlicher Größen und Komplexität zu entsprechen. Laravel bietet Routing-System, eloquentorm, Artisan Command Line und andere Funktionen und unterstützt die Entwicklung von einfachen Blogs bis hin zu komplexen Systemen auf Unternehmensebene.

Möchten Sie das Laravel -Rahmen lernen, aber unter keinen Ressourcen oder dem wirtschaftlichen Druck leiden? Dieser Artikel bietet Ihnen ein kostenloses Lernen von Laravel und lehrt Sie, wie Sie Ressourcen wie Online -Plattformen, Dokumente und Community -Foren verwenden, um eine solide Grundlage für Ihre PHP -Entwicklungsreise zu schaffen.

Die Popularität von Laravel umfasst seinen vereinfachten Entwicklungsprozess, eine angenehme Entwicklungsumgebung und umfangreiche Merkmale. 1) Es absorbiert die Designphilosophie von RubyonRails und kombiniert die Flexibilität von PHP. 2) Bereitstellung von Werkzeugen wie eloquentorm, Blade Template Engine usw. zur Verbesserung der Entwicklungseffizienz. 3) Sein MVC -Architektur- und Abhängigkeitsinjektionsmechanismus macht den Code modularer und prüfbarer. 4) Bietet leistungsstarke Debugging -Tools und Leistungsoptimierungsmethoden wie Caching -Systeme und Best Practices.
