Heim PHP-Framework Laravel API-Authentifizierung und Autorisierung mit Laravel: Schutz sensibler Daten und Vorgänge

API-Authentifizierung und Autorisierung mit Laravel: Schutz sensibler Daten und Vorgänge

Aug 26, 2023 pm 02:33 PM
laravel 授权 api认证

API-Authentifizierung und Autorisierung mit Laravel: Schutz sensibler Daten und Vorgänge

Verwendung von Laravel für API-Authentifizierung und -Autorisierung: Schutz sensibler Daten und Vorgänge

Übersicht:
API (Application Programming Interface) ist ein wichtiger Bestandteil der modernen Webanwendungsentwicklung, der die Dateninteraktion und den Funktionsaufruf zwischen verschiedenen Systemen ermöglicht. Bei API-Anwendungen ist die Datensicherheit von entscheidender Bedeutung. Laravel ist ein beliebtes PHP-Framework, das leistungsstarke API-Authentifizierungs- und Autorisierungsfunktionen bietet, die uns helfen können, sensible Daten und Vorgänge zu schützen und unbefugten Zugriff zu verhindern.

1. Laravel installieren und konfigurieren
Zunächst müssen wir Composer verwenden, um Laravel zu installieren. Führen Sie den folgenden Befehl in der Befehlszeile aus:

composer global require laravel/installer
Nach dem Login kopieren

Nachdem die Installation abgeschlossen ist, können wir mit dem folgenden Befehl ein neues Laravel-Projekt erstellen:

laravel new api-auth
Nach dem Login kopieren

Geben Sie das Verzeichnis ein, in dem sich das Projekt befindet:

cd api-auth
Nach dem Login kopieren

Als nächstes brauchen wir um einen Schlüssel zur Verschlüsselung unserer Benutzerdaten zu generieren. Führen Sie den folgenden Befehl aus:

php artisan key:generate
Nach dem Login kopieren

2. Erstellen Sie Dateien für die API-Authentifizierung und -Autorisierung.

  1. Benutzermodell erstellen: In Laravel verwenden wir häufig das Eloquent-Modell, um Daten in der Datenbank zu verwalten. Führen Sie den folgenden Befehl aus, um ein Benutzermodell zu generieren:
php artisan make:model User -m
Nach dem Login kopieren

Dieser Befehl generiert ein Benutzermodell und die entsprechende Datenbankmigrationsdatei.

  1. Erstellen Sie einen Benutzerauthentifizierungs-Controller: Führen Sie den folgenden Befehl aus, um einen Benutzerauthentifizierungs-Controller zu generieren:
php artisan make:controller AuthController
Nach dem Login kopieren
  1. Erstellen Sie eine API-Route: Bearbeiten Sie die Datei routes/api.php und definieren Sie die relevanten Routen für die API: routes/api.php文件,定义API的相关路由:
Route::post('login', 'AuthController@login');
Route::post('register', 'AuthController@register');
Route::middleware('auth:api')->group(function () {
    Route::get('user', 'AuthController@user');
    Route::post('logout', 'AuthController@logout');
});
Nach dem Login kopieren

以上路由定义了用户登录、注册、获取用户信息、注销等接口。

  1. 编写用户认证控制器:打开app/Http/Controllers/AuthController.php文件,编写以下代码:
namespace AppHttpControllers;

use IlluminateHttpRequest;
use AppUser;
use IlluminateSupportFacadesAuth;

class AuthController extends Controller
{
    public function register(Request $request)
    {
        $validatedData = $request->validate([
            'name' => 'required|max:55',
            'email' => 'email|required|unique:users',
            'password' => 'required|confirmed'
        ]);

        $validatedData['password'] = bcrypt($request->password);

        $user = User::create($validatedData);

        $accessToken = $user->createToken('authToken')->accessToken;

        return response(['user' => $user, 'access_token' => $accessToken]);
    }

    public function login(Request $request)
    {
        $loginData = $request->validate([
            'email' => 'email|required',
            'password' => 'required'
        ]);

        if (!Auth::attempt($loginData)) {
            return response(['message' => 'Invalid credentials']);
        }

        $accessToken = Auth::user()->createToken('authToken')->accessToken;

        return response(['user' => Auth::user(), 'access_token' => $accessToken]);
    }

    public function user()
    {
        return response(['user' => Auth::user()]);
    }

    public function logout(Request $request)
    {
        $request->user()->token()->revoke();
        return response(['message' => 'Successfully logged out']);
    }
}
Nach dem Login kopieren

以上代码中,我们定义了用户的注册、登录、获取用户信息和注销操作。

三、配置API认证和授权

  1. 配置Guard和Provider:打开config/auth.php文件,找到guardsproviders配置项,根据以下示例进行配置:
'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users'
    ],

    'api' => [
        'driver' => 'passport',
        'provider' => 'users',
    ]
],

'providers' => [
    'users' => [
        'driver' => 'eloquent',
        'model' => AppUser::class
    ]
],
Nach dem Login kopieren
  1. 运行数据库迁移:运行以下命令执行生成的数据库迁移:
php artisan migrate
Nach dem Login kopieren
  1. 配置Passport:运行以下命令,发布Passport的配置文件:
php artisan passport:install
Nach dem Login kopieren

执行完毕后,会生成一对加密的公钥和私钥,用来签发和验证访问令牌。

  1. 创建个人访问客户端:运行以下命令创建个人访问客户端:
php artisan passport:client --personal
Nach dem Login kopieren

五、测试API认证和授权

  1. 注册新用户:使用POST请求向http://localhost:8000/api/register发送以下数据:
{
    "name": "John Doe",
    "email": "johndoe@example.com",
    "password": "password",
    "password_confirmation": "password"
}
Nach dem Login kopieren
  1. 登录用户:使用POST请求向http://localhost:8000/api/login发送以下数据:
{
    "email": "johndoe@example.com",
    "password": "password"
}
Nach dem Login kopieren
  1. 获取用户信息:使用GET请求向http://localhost:8000/api/user发送请求,在Headers中添加Authorization: Bearer {access_token},其中{access_token}是登录时返回的访问令牌。
  2. 注销用户:使用POST请求向http://localhost:8000/api/logout发送请求,同样在Headers中添加Authorization: Bearer {access_token}
  3. rrreee
Die oben genannten Routen definieren Benutzeranmeldung, Registrierung, Erhalt von Benutzerinformationen, Abmeldung und andere Schnittstellen.

    Schreiben Sie einen Benutzerauthentifizierungs-Controller: Öffnen Sie die Datei app/Http/Controllers/AuthController.php und schreiben Sie den folgenden Code: 🎜🎜rrreee🎜Im obigen Code Wir definieren Benutzerregistrierung, Anmeldung, Erhalt von Benutzerinformationen und Abmeldevorgänge. 🎜🎜3. API-Authentifizierung und -Autorisierung konfigurieren 🎜🎜🎜Guard und Provider konfigurieren: Öffnen Sie die Datei config/auth.php und suchen Sie nach guards und providers Konfigurationselemente, konfigurieren Sie gemäß dem folgenden Beispiel: 🎜🎜rrreee🎜🎜Datenbankmigration ausführen: Führen Sie den folgenden Befehl aus, um die generierte Datenbankmigration auszuführen: 🎜🎜rrreee🎜🎜Passport konfigurieren: Führen Sie den folgenden Befehl aus, um die Passport-Konfigurationsdatei zu veröffentlichen: 🎜🎜rrreee🎜Ausführen Nach Abschluss wird ein verschlüsseltes Paar aus öffentlichen und privaten Schlüsseln generiert, um das Zugriffstoken auszustellen und zu überprüfen. 🎜
      🎜Erstellen Sie einen Client für den persönlichen Zugriff: Führen Sie den folgenden Befehl aus, um einen Client für den persönlichen Zugriff zu erstellen: 🎜🎜rrreee🎜 5. Testen Sie die API-Authentifizierung und -Autorisierung. 🎜🎜🎜Registrieren Sie einen neuen Benutzer: Verwenden Sie die POST-Anfrage, um http://localhost:8000/api/register sendet die folgenden Daten: 🎜🎜rrreee🎜🎜Angemeldeter Benutzer: Verwenden Sie eine POST-Anfrage an http://localhost:8000/api/login Die folgenden Daten: 🎜🎜rrreee🎜🎜 Benutzerinformationen abrufen: Verwenden Sie die GET-Anfrage, um eine Anfrage an http://localhost:8000/api/user zu senden, fügen Sie Autorisierung hinzu: Träger {access_token} in Headern , wobei {access_token} das beim Anmelden zurückgegebene Zugriffstoken ist. 🎜🎜Benutzer abmelden: Verwenden Sie die POST-Anfrage, um eine Anfrage an http://localhost:8000/api/logout zu senden, und fügen Sie außerdem Authorization: Bearer {access_token hinzu in den Headern. 🎜🎜🎜 Oben haben wir sensible Daten und Vorgänge erfolgreich durch die API-Authentifizierungs- und Autorisierungsfunktionen von Laravel geschützt. Mithilfe des Benutzermodells, Controllers, Routings und der von Passport bereitgestellten Funktionen können wir die Authentifizierung und Autorisierungskontrolle der API problemlos implementieren. 🎜

Das obige ist der detaillierte Inhalt vonAPI-Authentifizierung und Autorisierung mit Laravel: Schutz sensibler Daten und Vorgänge. 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
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate 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.

Laravel – Artisan-Konsole Laravel – Artisan-Konsole Aug 27, 2024 am 10:51 AM

Laravel – Artisan Console – Das Laravel-Framework bietet drei Haupttools für die Interaktion über die Befehlszeile, nämlich Artisan, Ticker und REPL. In diesem Kapitel wird Artisan ausführlich erläutert.

See all articles