Heim PHP-Framework Laravel So implementieren Sie eine system- und domänenübergreifende Berechtigungsverwaltung in Laravel

So implementieren Sie eine system- und domänenübergreifende Berechtigungsverwaltung in Laravel

Nov 02, 2023 pm 05:02 PM
laravel 权限管理 Domänenübergreifende Autorisierung

So implementieren Sie eine system- und domänenübergreifende Berechtigungsverwaltung in Laravel

Als beliebtes PHP-Framework verfügt Laravel über umfangreiche Funktionen und ein hervorragendes Erweiterungssystem. Im Hinblick auf die Implementierung der Berechtigungsverwaltung bietet Laravel außerdem umfassende Unterstützung, mit der verschiedene berechtigungsbezogene Funktionen problemlos im System implementiert werden können. In tatsächlichen Anwendungen kann es sich jedoch um eine Berechtigungsverwaltung zwischen mehreren Systemen oder eine domänenübergreifende Berechtigungsüberprüfung handeln. In diesem Fall müssen Sie die system- und domänenübergreifenden Berechtigungsverwaltungsfunktionen von Laravel verwenden.

In diesem Artikel wird die Implementierung einer system- und domänenübergreifenden Berechtigungsverwaltung in Laravel vorgestellt. Der Inhalt umfasst hauptsächlich die folgenden Inhalte:

  1. Grundkenntnisse der Berechtigungsverwaltung in Laravel.
  2. So implementieren Sie eine systemübergreifende Berechtigungsverwaltung.
  3. Anleitung um domänenübergreifende Berechtigungen zu implementieren Verify
  4. Grundkenntnisse der Berechtigungsverwaltung in Laravel

In Laravel kann die Berechtigungsverwaltung über das Laravel-eigene Auth-System erreicht werden. Das Auth-System bietet Funktionen wie Benutzerauthentifizierung, Autorisierung und Passwort-Reset. Die Autorisierungsfunktion wird hauptsächlich über die Klassen Gate und Policy implementiert.

Gate ist die Kernklasse, die die Autorisierung in Laravel implementiert. Sie können damit Benutzerberechtigungen definieren und festlegen. In Laravel können Sie ein Gate in der Datei app/Providers/AuthServiceProvider.php definieren:

public function boot()
{
    $this->registerPolicies();

    Gate::define('update-post', function ($user, $post) {
        return $user->id === $post->user_id;
    });
}
Nach dem Login kopieren

Das obige Beispiel definiert ein Gate mit dem Namen „update-post“, um zu bestimmen, ob der aktuelle Benutzer die Berechtigung zum Ändern eines Artikels hat. Die Beurteilungsbedingung besteht darin, dass die aktuelle Benutzer-ID mit der Autoren-ID des Artikels übereinstimmt.

Wenn Sie Gate zum Ermitteln von Berechtigungen verwenden, können Sie direkt die Autorisierungsmethode verwenden:

public function update(Request $request, Post $post)
{
    $this->authorize('update-post', $post);

    //...
}
Nach dem Login kopieren

Wenn der aktuelle Benutzer zu diesem Zeitpunkt keine Berechtigung zum Ändern des Artikels hat, wird eine 403-Ausnahme ausgelöst. Wenn Sie die Ausnahmeinformationen anpassen müssen, können Sie den dritten Parameter im Text übergeben, z. B.:

$this->authorize('update-post', $post, '你没有权限修改这篇文章');
Nach dem Login kopieren

Wenn der aktuelle Benutzer zu diesem Zeitpunkt keine Berechtigung zum Ändern des Artikels hat, wird eine 403-Ausnahme ausgelöst. und die Ausnahmemeldung lautet „Sie haben keine Berechtigung, diesen Artikel zu ändern“.

Im obigen Beispiel haben wir die direkte Übertragung des $post-Objekts zur Berechtigungsbestimmung verwendet. Wenn Sie zur Berechtigungsbeurteilung andere Parameter übergeben müssen, können Sie natürlich auch zusätzliche Daten in Form eines Arrays über den dritten Parameter übergeben:

$this->authorize('update-post', ['post' => $post, 'extra_data' => 'foo']);
Nach dem Login kopieren

Bei der Beurteilung in Gate können Sie die übergebenen Daten über den zweiten Parameter abrufen:

Gate::define('update-post', function ($user, $post, $extra_data) {
    // can access $extra_data['extra_data'] here
    return $user->id === $post->user_id;
});
Nach dem Login kopieren

Außer neben Gate stellt Laravel auch eine weitere Klasse namens Policy zur Verfügung, die ebenfalls zur Implementierung der Autorisierung verwendet werden kann. Im Vergleich dazu ist Policy flexibler und ermöglicht es Entwicklern, eine detailliertere Berechtigungskontrolle zu implementieren, indem sie eine öffentliche Methode namens can definieren:

class PostPolicy
{
    public function canUpdate($user, Post $post)
    {
        return $user->id === $post->user_id;
    }
}
Nach dem Login kopieren

Wenn Sie derzeit Gate zur Berechtigungsbeurteilung verwenden, können Sie die Richtlinienmethode Associate Gate und verwenden Richtlinie:

Gate::policy(Post::class, PostPolicy::class);

$this->authorize('update', $post);
Nach dem Login kopieren

Im obigen Beispiel verknüpfen wir die Gate- und PostPolicy-Klassen über die Richtlinienmethode, sodass Laravel bei Verwendung der Autorisierungsmethode automatisch die canUpdate-Methode von PostPolicy aufruft, um Berechtigungen zu ermitteln. Wenn der aktuelle Benutzer zu diesem Zeitpunkt keine Berechtigung zum Ändern des Artikels hat, wird eine 403-Ausnahme ausgelöst.

  1. So implementieren Sie ein systemübergreifendes Berechtigungsmanagement

In praktischen Anwendungen kann es erforderlich sein, Berechtigungsinformationen von einem System auf ein anderes zu übertragen. Wenn wir beispielsweise die Authentifizierung und Autorisierung in System A abgeschlossen haben, müssen wir nun Vorgänge in System B ausführen, möchten aber nicht, dass sich der Benutzer erneut authentifizieren und autorisieren muss. Zu diesem Zeitpunkt können wir die Autorisierungsinformationen in System A auf System B übertragen, um eine nahtlose Berechtigungsverwaltung zu erreichen.

In Laravel können wir JWT (JSON Web Token) verwenden, um eine systemübergreifende Berechtigungsverwaltung zu erreichen. JWT ist ein offener Standard für die sichere Übertragung von Informationen in einer Netzwerkumgebung. Es legt fest, wie JSON-basierte Informationen sicher über das Internet übertragen werden. JWT besteht aus drei Teilen, nämlich Header, Payload und Signatur. Dabei handelt es sich bei Header und Payload um mit Base64 codierte JSON-Strings, während es sich bei der Signatur um einen Hash-Wert handelt, der mithilfe von Verschlüsselungsalgorithmen wie HS256 aus Header, Payload und Secret generiert wird.

In Laravel können wir das Erweiterungspaket tymon/jwt-auth verwenden, um JWT zu erstellen und zu analysieren. Zuerst müssen Sie das Erweiterungspaket tymon/jwt-auth installieren:

composer require tymon/jwt-auth
Nach dem Login kopieren

Nachdem die Installation abgeschlossen ist, müssen wir einige grundlegende Konfigurationen von JWT durchführen. Es kann in der Datei config/jwt.php konfiguriert werden und umfasst hauptsächlich:

  • Geheimnis: Verschlüsselungsschlüssel
  • ttl: Token-Gültigkeitsdauer in Minuten
  • Anbieter: Benutzeranbieter, der zur Überprüfung der Benutzeridentität verwendet wird
return [
    // ...

    'secret' => env('JWT_SECRET', 'some-secret-string'),

    'ttl' => env('JWT_TTL', 60),

    'refresh_ttl' => env('JWT_REFRESH_TTL', 20160),

    'providers' => [
        'users' => [
            'model' => AppModelsUser::class,
            'credentials' => ['email', 'password'],
        ],
    ],

    // ...
];
Nach dem Login kopieren

Nachher Nach Abschluss der Konfiguration können wir ein JWT in einem System generieren und es an ein anderes System übergeben. In einem anderen System kann die JWT-Analysefunktion verwendet werden, um die Benutzerinformationen und Berechtigungsinformationen im JWT abzurufen. Insbesondere können Sie die Methode Auth::setUser verwenden, um die analysierten Benutzerinformationen auf den aktuellen Benutzer festzulegen, und Gate verwenden, um Berechtigungen zu bestimmen.

Das Folgende ist ein einfaches Beispiel:

In System A können wir JWT verwenden, um ein Token zu generieren und es an System B zu übergeben:

$token = JWTAuth::fromUser($user);

return redirect('http://system-b.com?token=' . $token);
Nach dem Login kopieren

In System B können wir das Token aus den Benutzerinformationen und Berechtigungsinformationen analysieren :

use IlluminateSupportFacadesAuth;
use TymonJWTAuthFacadesJWTAuth;

$token = request()->get('token');

$user = JWTAuth::parseToken()->authenticate();

Auth::setUser($user);

// ...

Gate::authorize('update', $post);
Nach dem Login kopieren

在上面的例子中,我们使用JWTAuth::parseToken()方法解析Token,成功后,通过authenticate()方法获取到用户信息,并使用Auth::setUser方法将用户信息设置为当前用户。最后,我们可以使用Gate的authorize方法判断当前用户是否有权限进行某些操作。

需要注意的是,为了保证传输安全,我们应该务必在传送Token时进行加密传输,或使用HTTPS协议进行通信。

  1. 如何实现跨域的权限验证

在实际应用中,由于系统之间的跨域限制,可能会导致无法直接进行权限验证。此时,我们可以使用跨域资源共享(CORS)解决跨域问题。CORS是一种允许服务器进行跨域访问的机制,可以通过在响应头中设置Access-Control-Allow-*等相关选项实现。

在Laravel中,要启用CORS,可以使用spatie/laravel-cors扩展包。首先需要安装该扩展包:

composer require spatie/laravel-cors
Nach dem Login kopieren

然后,在config/cors.php文件中进行配置:

return [
    'paths' => ['api/*'],

    'allowed_methods' => ['*'],

    'allowed_origins' => ['*'],

    'allowed_origins_patterns' => [],

    'allowed_headers' => ['*'],

    'exposed_headers' => [],

    'max_age' => 0,

    'supports_credentials' => true,
];
Nach dem Login kopieren

在完成配置后,我们可以在需要使用CORS的路由或控制器中添加CORS相关中间件:

Route::group(['middleware' => ['cors']], function () {
    // ...
});  

public function update(Request $request, Post $post)
{
    $this->authorize('update-post', $post);

    //...
}
Nach dem Login kopieren

在上面的例子中,我们通过将路由或控制器添加到“cors”中间件组中,启用了CORS功能。此时,我们就可以支持跨域的权限验证了。

需要注意的是,为了避免出现安全问题,我们需要仔细配置CORS相关参数,确保只允许来自指定域名和端口的请求访问我们的系统。同时,我们也需要在服务器端使用CSRF和其他相关功能保护系统的安全。

以上就是So implementieren Sie eine system- und domänenübergreifende Berechtigungsverwaltung in Laravel的详细介绍。需要说明的是,本文只是提供了一些基本的实现思路和代码示例,具体的实现细节和方案根据实际的应用情况会有所不同。

Das obige ist der detaillierte Inhalt vonSo implementieren Sie eine system- und domänenübergreifende Berechtigungsverwaltung in Laravel. 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
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 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)

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