Inhaltsverzeichnis
Einführung
Installation
Test
Heim Backend-Entwicklung PHP-Tutorial Wie werden die Autorisierungsanforderungen in API-Szenarien erfüllt?

Wie werden die Autorisierungsanforderungen in API-Szenarien erfüllt?

Jun 23, 2017 am 11:46 AM
api laravel Erstellen Sie eine Website 系统 认证

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
Nach dem Login kopieren

Als nächstes registrieren Sie den Passport-Dienstanbieter im Provider-Array der Konfigurationsdatei config/app.php:

Laravel\Passport\PassportServiceProvider::class
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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 = [&#39;App\Model&#39; => '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));
    }
}
Nach dem Login kopieren

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',],],
Nach dem Login kopieren

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');
});
Nach dem Login kopieren

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()]);
    }
}
Nach dem Login kopieren

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!

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ß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)

Huawei wird das Xuanji-Sensorsystem im Bereich Smart Wearables auf den Markt bringen, das den emotionalen Zustand des Benutzers anhand der Herzfrequenz beurteilen kann Huawei wird das Xuanji-Sensorsystem im Bereich Smart Wearables auf den Markt bringen, das den emotionalen Zustand des Benutzers anhand der Herzfrequenz beurteilen kann Aug 29, 2024 pm 03:30 PM

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 – 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 – Paginierungsanpassungen Laravel – Paginierungsanpassungen Aug 27, 2024 am 10:51 AM

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

Wie bekomme ich den Rückgabecode, wenn das Senden von E -Mails in Laravel fehlschlägt? Wie bekomme ich den Rückgabecode, wenn das Senden von E -Mails in Laravel fehlschlägt? Apr 01, 2025 pm 02:45 PM

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 -Zeitplanaufgabe wird nicht ausgeführt: Was soll ich tun, wenn die Aufgabe nicht nach Zeitplan ausgeführt wird: Befehl ausführen? Laravel -Zeitplanaufgabe wird nicht ausgeführt: Was soll ich tun, wenn die Aufgabe nicht nach Zeitplan ausgeführt wird: Befehl ausführen? Mar 31, 2025 pm 11:24 PM

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 ...

Wie kann man in Laravel mit der Situation umgehen, in der Überprüfungscodes nicht per E -Mail gesendet werden? Wie kann man in Laravel mit der Situation umgehen, in der Überprüfungscodes nicht per E -Mail gesendet werden? Mar 31, 2025 pm 11:48 PM

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

So implementieren Sie die benutzerdefinierte Tabellenfunktion des Klickens, um Daten im DCAT -Administrator hinzuzufügen? So implementieren Sie die benutzerdefinierte Tabellenfunktion des Klickens, um Daten im DCAT -Administrator hinzuzufügen? Apr 01, 2025 am 07:09 AM

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

Laravel – Dump-Server Laravel – Dump-Server Aug 27, 2024 am 10:51 AM

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.

See all articles