


Wie werden die Autorisierungsanforderungen in API-Szenarien erfüllt?
Einführung
In Laravel ist es sehr einfach, Anmeldung und Autorisierung auf der Grundlage herkömmlicher Formulare zu implementieren, aber wie erfüllt man die Autorisierungsanforderungen in API-Szenarien? In API-Szenarien wird die Benutzerautorisierung normalerweise über Token implementiert, anstatt den Sitzungsstatus zwischen Anforderungen aufrechtzuerhalten. Passport kann jetzt zur einfachen Implementierung des API-Autorisierungsprozesses in Laravel-Projekten verwendet werden. Mit Passport können Sie Ihrer Anwendung in wenigen Minuten eine vollständige OAuth2-Serverimplementierung hinzufügen.
Installation
Verwenden Sie den Composer-Abhängigkeitspaketmanager, um Passport zu installieren:
composer require laravel/passport
Als nächstes registrieren Sie den Passport-Dienstanbieter im Provider-Array der Konfigurationsdatei config/app.php:
Laravel\Passport\PassportServiceProvider::class
Passport verwendet Dienstanbieter, um das interne Datenbankmigrationsskriptverzeichnis zu registrieren. Nachdem der vorherige Schritt abgeschlossen ist, benötigen Sie also um Ihre Datenbankstruktur zu aktualisieren. Das Migrationsskript von Passport erstellt automatisch die von der Anwendung benötigte Client-Datentabelle und Token-Datentabelle:
php artisan migrate
Als nächstes müssen Sie den Passport:install-Befehl ausführen, um die generierte Sicherheit zu erstellen Der für das Zugriffstoken verwendete Verschlüsselungsschlüssel erstellt gleichzeitig auch den „Private Access“-Client und den „Password Authorization“-Client:
php artisan passport:install
Das Obige Befehl Ändern Sie nach der Ausführung AppUser.php, um das Token und den Nutzungsbereich des authentifizierten Benutzers zu überprüfen:
<?php namespace App;use Laravel\Passport\HasApiTokens; // 新增use Illuminate\Notifications\Notifiable;use Illuminate\Foundation\Auth\User as Authenticatable;class User extends Authenticatable {use HasApiTokens, Notifiable; // 增加 HasApiTokens
Als nächstes müssen Sie Passport in der Boot-Methode von AuthServiceProvider aufrufen: :routes-Funktion . Diese Funktion registriert einige notwendige Routen, die im Ausstellungs- und Widerrufsprozess von Zugriffstokens, Clients und privaten Zugriffstokens verwendet werden:
AppProvidersAuthServiceProvider.php ändern:
<?php namespace App\Providers;use Laravel\Passport\Passport; // 新增use Illuminate\Support\Facades\Gate;use Illuminate\Foundation\Support\Providers\AuthServiceProvider as ServiceProvider;use Carbon\Carbon; // 新增引用class AuthServiceProvider extends ServiceProvider {/** * The policy mappings for the application. * * @var array */protected $policies = ['App\Model' => 'App\Policies\ModelPolicy',];/** * Register any authentication / authorization services. * * @return void */public function boot() {$this->registerPolicies(); Passport::routes(); // 注册passport路由 //令牌的有效期Passport::tokensExpireIn(Carbon::now()->addDays(15)); Passport::refreshTokensExpireIn(Carbon::now()->addDays(30)); } }
Schließlich müssen Sie das Autorisierungsschutzelement (Treiber) im API-Teil der Konfigurationsdatei config/auth.php in Passport ändern. Diese Anpassung führt dazu, dass Ihre Anwendung den TokenGuard von Passport verwendet, wenn Autorisierungsanfragen von der API empfangen werden:
'guards' => ['web' => ['driver' => 'session', 'provider' => 'users',], 'api' => ['driver' => 'passport', // 改为passport'provider' => 'users',],],
Test
api Die Route ist api.php . Öffnen Sie „routesapi.php“ und fügen Sie Testrouten hinzu.
Route::group(['namespace' => 'api'], function () { Route::post('/login', 'UserController@login'); }); Route::group(['middleware' => 'auth:api', 'namespace' => 'api'], function() { Route::get('details', 'UserController@details'); });
Einer wird zum Anmelden und Erhalten des Tokens verwendet, und der andere wird verwendet, um die Anmeldeüberprüfung mit dem erhaltenen Token abzuschließen und die aktuellen Benutzerinformationen zu erhalten.
Das Detailrouting verwendet die auth:api-Middleware, um das Token zu überprüfen.
Erstellen Sie einen API-Ordner im AppHttp-Verzeichnis und fügen Sie UserController.php hinzu
<?php namespace App\Http\Controllers\api;use Illuminate\Http\Request;use App\Http\Controllers\Controller;use Illuminate\Support\Facades\Auth;use App\User;use Response;class UserController extends Controller {public function __construct() {$this->content = array(); }public function login() {if(Auth::attempt(['email' => request('email'), 'password' => request('password')])) {$user = Auth::user();$this->content['token'] = $user->createToken('Pizza App')->accessToken;$status = 200; } else {$this->content['error'] = "未授权"; $status = 401; } return response()->json($this->content, $status); }public function details() {return response()->json(['user' => Auth::user()]); } }
Test im Postman:
Wie im Bild oben gezeigt, muss die Anmeldemethode mit der Route übereinstimmen, die Post-Methode verwenden und die E-Mail-Adresse und das Passwort des Benutzers in einem Formular an api/login übergeben
Bei korrekter Weitergabe erhalten Sie den Token im Bild oben
Fügen Sie den im vorherigen Schritt erhaltenen Token zur Kopfzeile hinzu und fügen Sie „Bearer“ hinzu ' vor dem Token '. Dann können Sie die Informationen des aktuellen Benutzers abrufen. Das heißt, die Benutzerauthentifizierung ist abgeschlossen.
Es kann nicht garantiert werden, dass das Obige vollständig korrekt ist. Willkommen, um meinen GitHub-Code anzusehen.
Das obige ist der detaillierte Inhalt vonWie werden die Autorisierungsanforderungen in API-Szenarien erfüllt?. 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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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



Kürzlich gab Huawei bekannt, dass es im September ein neues intelligentes tragbares Produkt mit dem Xuanji-Sensorsystem auf den Markt bringen wird, bei dem es sich voraussichtlich um die neueste Smartwatch von Huawei handeln wird. Dieses neue Produkt wird fortschrittliche Funktionen zur Überwachung der emotionalen Gesundheit integrieren. Das Xuanji Perception System bietet Benutzern eine umfassende Gesundheitsbewertung mit seinen sechs Merkmalen – Genauigkeit, Vollständigkeit, Geschwindigkeit, Flexibilität, Offenheit und Skalierbarkeit. Das System nutzt ein Super-Sensing-Modul und optimiert die Mehrkanal-Optikpfad-Architekturtechnologie, wodurch die Überwachungsgenauigkeit grundlegender Indikatoren wie Herzfrequenz, Blutsauerstoff und Atemfrequenz erheblich verbessert wird. Darüber hinaus hat das Xuanji Sensing System auch die Erforschung emotionaler Zustände auf Basis von Herzfrequenzdaten erweitert. Es beschränkt sich nicht nur auf physiologische Indikatoren, sondern kann auch den emotionalen Zustand und das Stressniveau des Benutzers bewerten. Es unterstützt die Überwachung von mehr als 60 Sportarten Gesundheitsindikatoren, die kardiovaskuläre, respiratorische, neurologische, endokrine,

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 – Paginierungsanpassungen – Laravel enthält eine Paginierungsfunktion, die einem Benutzer oder Entwickler hilft, eine Paginierungsfunktion einzubinden. Der Laravel-Paginator ist in den Abfrage-Builder und Eloquent ORM integriert. Die Paginierungsmethode automatisch

Methode zum Abholen des Rücksendecode, wenn das Senden von Laravel -E -Mails fehlschlägt. Wenn Sie Laravel zur Entwicklung von Anwendungen verwenden, stellen Sie häufig Situationen auf, in denen Sie Überprüfungscodes senden müssen. Und in Wirklichkeit ...

Laravel -Zeitplan -Aufgabe Ausführen nicht reagierende Fehlerbehebung Bei Verwendung der Zeitplanung von Laravel -Zeitplänen werden viele Entwickler auf dieses Problem stoßen: Zeitplan: Run ...

Die Methode zum Umgang mit Laravels E -Mail -Versagen zum Senden von Verifizierungscode besteht darin, Laravel zu verwenden ...

So implementieren Sie die Tabellenfunktion von benutzerdefiniertem Klicken, um Daten in dcatadmin (laravel-admin) hinzuzufügen, wenn Sie DCAT verwenden ...

Laravel – Dump-Server – Der Laravel-Dump-Server wird mit der Version von Laravel 5.7 geliefert. Die Vorgängerversionen enthalten keinen Dump-Server. Der Dump-Server wird eine Entwicklungsabhängigkeit in der Laravel-/Laravel-Composer-Datei sein.
