Heim > PHP-Framework > Laravel > Hauptteil

Die neueste Entwicklung der Berechtigungsfunktion von Laravel: Umgang mit der Berechtigungsverwaltung in einer mandantenfähigen Umgebung

WBOY
Freigeben: 2023-11-04 12:52:51
Original
986 Leute haben es durchsucht

Die neueste Entwicklung der Berechtigungsfunktion von Laravel: Umgang mit der Berechtigungsverwaltung in einer mandantenfähigen Umgebung

Die neueste Entwicklung der Laravel-Berechtigungsfunktion: Für den Umgang mit der Berechtigungsverwaltung in einer mandantenfähigen Umgebung sind spezifische Codebeispiele erforderlich

In den letzten Jahren mit dem Aufkommen von Cloud Computing und Software as a Service (SaaS) Die Verwaltung von Berechtigungen in einer mandantenfähigen Umgebung wird zu einer wichtigen Herausforderung in der Softwareentwicklung. In dieser Umgebung nutzen mehrere Benutzer oder Organisationen dieselbe Anwendung gemeinsam und jeder Benutzer oder jede Organisation kann nur auf seine eigenen Daten und Funktionen zugreifen. In einem solchen Szenario stellt die Frage, wie sichergestellt werden kann, dass Benutzer nur auf Ressourcen zugreifen können, für die sie eine Berechtigung haben, ein Problem dar, das gelöst werden muss.

Als leistungsstarkes PHP-Entwicklungsframework bietet Laravel umfangreiche Berechtigungsverwaltungsfunktionen. Die neueste Laravel-Version verbessert die Berechtigungsverwaltungsfunktion in einer mandantenfähigen Umgebung weiter und macht sie einfacher zu verwenden und zu konfigurieren. In diesem Artikel stellen wir vor, wie Sie Laravel für die Berechtigungsverwaltung in einer mandantenfähigen Umgebung verwenden, und stellen spezifische Codebeispiele bereit.

In Laravel werden Berechtigungen normalerweise über die beiden Konzepte Rollen und Berechtigungen verwaltet. Rollen definieren die Identität oder Rolle eines Benutzers, während Berechtigungen die spezifischen Aktionen definieren, die ein Benutzer ausführen kann. Durch die Verknüpfung von Rollen und Berechtigungen können wir die Berechtigungen der Benutzer einfach verwalten.

Zuerst müssen wir entsprechende Tabellen in der Datenbank erstellen, um Rollen- und Berechtigungsinformationen zu speichern. In Laravel können diese Tabellen durch Migrationen erstellt werden. Hier ist eine Beispielmigration, die Rollen- und Berechtigungstabellen erstellt:

use IlluminateDatabaseMigrationsMigration;
use IlluminateDatabaseSchemaBlueprint;
use IlluminateSupportFacadesSchema;

class CreateRolesAndPermissionsTable extends Migration
{
    public function up()
    {
        Schema::create('roles', function (Blueprint $table) {
            $table->id();
            $table->string('name')->unique();
            $table->timestamps();
        });

        Schema::create('permissions', function (Blueprint $table) {
            $table->id();
            $table->string('name')->unique();
            $table->timestamps();
        });

        Schema::create('role_permission', function (Blueprint $table) {
            $table->id();
            $table->unsignedBigInteger('role_id');
            $table->unsignedBigInteger('permission_id');
            $table->timestamps();

            $table->foreign('role_id')->references('id')->on('roles')->onDelete('cascade');
            $table->foreign('permission_id')->references('id')->on('permissions')->onDelete('cascade');
        });
    }

    public function down()
    {
        Schema::dropIfExists('role_permission');
        Schema::dropIfExists('roles');
        Schema::dropIfExists('permissions');
    }
}
Nach dem Login kopieren

Bei dieser Migration erstellen wir die roles-Tabelle, die permissions-Tabelle und die role_permission</ code >Tabelle zum Speichern von Rollen- und Berechtigungsinformationen. Die Tabelle <code>role_permission ist eine Zuordnungstabelle von Rollen und Berechtigungen. roles表、permissions表和role_permission表来存储角色和权限的信息。role_permission表是角色和权限的关联表。

接下来,我们可以使用Laravel的认证和授权系统来管理用户的角色和权限。首先,在User模型中定义用户与角色的关联关系:

use IlluminateFoundationAuthUser as Authenticatable;
use IlluminateDatabaseEloquentRelationsBelongsToMany;

class User extends Authenticatable
{
    public function roles(): BelongsToMany
    {
        return $this->belongsToMany(Role::class);
    }
}
Nach dem Login kopieren

Role模型中定义角色与权限的关联关系:

use IlluminateDatabaseEloquentModel;
use IlluminateDatabaseEloquentRelationsBelongsToMany;

class Role extends Model
{
    public function permissions(): BelongsToMany
    {
        return $this->belongsToMany(Permission::class);
    }
}
Nach dem Login kopieren

然后,在需要进行权限验证的地方,我们可以使用Laravel的授权系统来检查用户是否有执行某个操作的权限。以下是一个检查用户是否有创建新用户的权限的示例:

use IlluminateSupportFacadesGate;

if (Gate::allows('create-user')) {
    // 用户有创建新用户的权限
} else {
    // 用户没有权限
}
Nach dem Login kopieren

在上面的示例中,我们使用Gate::allows()方法来判断用户是否有执行create-user操作的权限。如果用户有权限,我们就可以执行相应的操作;否则,我们可以抛出一个异常或者显示一个错误信息。

最后,我们需要为不同的租户分配角色和权限。在多租户环境下,每个租户可能有自己独立的角色和权限。我们可以使用Laravel提供的事件和订阅者来实现这一功能。以下是一个为新建租户分配角色和权限的示例:

use AppEventsTenantCreated;
use AppListenersAssignDefaultRolesAndPermissionsToTenant;

Event::listen(
    TenantCreated::class,
    AssignDefaultRolesAndPermissionsToTenant::class
);

class AssignDefaultRolesAndPermissionsToTenant
{
    public function handle(TenantCreated $event)
    {
        $tenant = $event->tenant;

        // 为租户分配默认角色和权限
        $defaultRole = Role::where('name', 'tenant')->first();
        $defaultPermission = Permission::where('name', 'create-resource')->first();
        $tenant->roles()->attach($defaultRole);
        $defaultRole->permissions()->attach($defaultPermission);
    }
}
Nach dem Login kopieren

在上面的示例中,我们定义了一个TenantCreated事件和一个AssignDefaultRolesAndPermissionsToTenant订阅者。当新建一个租户时,系统会触发TenantCreated事件,然后AssignDefaultRolesAndPermissionsToTenant

Als nächstes können wir das Authentifizierungs- und Autorisierungssystem von Laravel verwenden, um Benutzerrollen und Berechtigungen zu verwalten. Definieren Sie zunächst die Zuordnung zwischen Benutzern und Rollen im Benutzer-Modell:

rrreee

Definieren Sie die Zuordnung zwischen Rollen und Berechtigungen im Role-Modell:

rrreee

Dann bei Bedarf Zur Berechtigungsüberprüfung können wir das Autorisierungssystem von Laravel verwenden, um zu prüfen, ob der Benutzer die Berechtigung hat, einen bestimmten Vorgang auszuführen. Das Folgende ist ein Beispiel für die Überprüfung, ob der Benutzer die Berechtigung zum Erstellen eines neuen Benutzers hat: 🎜rrreee🎜 Im obigen Beispiel verwenden wir die Methode Gate::allows(), um zu ermitteln, ob der Benutzer ausgeführt hat create -userBerechtigung zum Betrieb. Wenn der Benutzer die entsprechende Berechtigung hat, können wir den entsprechenden Vorgang ausführen. Andernfalls können wir eine Ausnahme auslösen oder eine Fehlermeldung anzeigen. 🎜🎜Abschließend müssen wir verschiedenen Mietern Rollen und Berechtigungen zuweisen. In einer Umgebung mit mehreren Mandanten kann jeder Mandant seine eigenen unabhängigen Rollen und Berechtigungen haben. Um diese Funktionalität zu erreichen, können wir die von Laravel bereitgestellten Ereignisse und Abonnenten nutzen. Hier ist ein Beispiel für die Zuweisung von Rollen und Berechtigungen zu einem neu erstellten Mandanten: 🎜rrreee🎜 Im obigen Beispiel haben wir ein TenantCreated-Ereignis und einen AssignDefaultRolesAndPermissionsToTenant-Abonnenten definiert. Wenn ein neuer Mandant erstellt wird, löst das System das Ereignis TenantCreated aus und dann weist der Abonnent AssignDefaultRolesAndPermissionsToTenant dem neu erstellten Mandanten Standardrollen und Berechtigungen zu. 🎜🎜Durch die oben genannten Schritte können wir die Berechtigungsverwaltung in einer mandantenfähigen Umgebung in Laravel implementieren. Die Berechtigungsfunktion von Laravel bietet flexible Konfigurationsoptionen und eine benutzerfreundliche Oberfläche, wodurch die Verwaltung von Berechtigungen in einer Umgebung mit mehreren Mandanten einfacher wird. Gleichzeitig können wir Berechtigungsfunktionen flexibel an den tatsächlichen Bedarf anpassen und erweitern, um uns an unterschiedliche Geschäftsszenarien anzupassen. 🎜🎜Zusammenfassend lässt sich sagen, dass Laravel in der neuesten Version die Berechtigungsverwaltungsfunktion in mandantenfähigen Umgebungen weiter verbessert hat. Durch die Einrichtung von Rollen- und Berechtigungstabellen, die Definition von Modellbeziehungen, die Verwendung von Authentifizierungs- und Autorisierungssystemen sowie die Verwendung von Ereignissen und Abonnenten können wir die Berechtigungsverwaltung problemlos in einer mandantenfähigen Umgebung implementieren. Ich hoffe, dass die obigen Codebeispiele Ihnen helfen können, die Berechtigungsfunktionen von Laravel besser zu verstehen und anzuwenden und Ihre Anwendung in einer Umgebung mit mehreren Mandanten sicherer und zuverlässiger zu machen. 🎜

Das obige ist der detaillierte Inhalt vonDie neueste Entwicklung der Berechtigungsfunktion von Laravel: Umgang mit der Berechtigungsverwaltung in einer mandantenfähigen Umgebung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!