Maison cadre php Laravel Comment implémenter un système de gestion des autorisations dans Laravel

Comment implémenter un système de gestion des autorisations dans Laravel

Nov 02, 2023 pm 04:51 PM
laravel 系统实现 权限管理

Comment implémenter un système de gestion des autorisations dans Laravel

Comment implémenter un système de gestion des autorisations dans Laravel

Introduction :
Avec le développement continu des applications Web, le système de gestion des autorisations est devenu l'une des fonctions de base de nombreuses applications. Laravel, en tant que framework PHP populaire, fournit une multitude d'outils et de fonctions pour mettre en œuvre des systèmes de gestion des autorisations. Cet article présentera comment implémenter un système de gestion des autorisations simple et puissant dans Laravel et fournira des exemples de code spécifiques.

1. Idées de conception d'un système de gestion des autorisations
Lors de la conception d'un système de gestion des autorisations, vous devez prendre en compte les points clés suivants :

  1. Définition des rôles et des autorisations : le rôle fait référence à la fonction ou à l'identité de l'utilisateur, et les autorisations font référence à l'utilisateur. Contrôle de l'utilisateur sur le système Accès aux fonctionnalités ou aux ressources.
  2. La relation entre les utilisateurs et les rôles : un utilisateur peut avoir plusieurs rôles, et un rôle peut appartenir à plusieurs utilisateurs.
  3. La relation entre les autorisations et les rôles : un rôle peut avoir plusieurs autorisations, et une autorisation peut appartenir à plusieurs rôles.
  4. La relation entre le routage et les autorisations : le routage détermine l'entrée permettant aux utilisateurs d'accéder aux fonctions du système. Différents itinéraires peuvent nécessiter différentes autorisations pour restreindre l'accès.

Sur la base des idées de conception ci-dessus, nous pouvons commencer à implémenter le système de gestion des autorisations dans Laravel.

2. Conception et migration de bases de données
Dans Laravel, nous pouvons utiliser la migration de bases de données pour créer et modifier des tables de base de données. Ce qui suit est une conception de base de données simple :

  1. Table des utilisateurs (utilisateurs) : stocke les informations de base des utilisateurs, telles que le nom d'utilisateur, le mot de passe, etc.
  2. Table des rôles (rôles) : stocke les informations de base sur les rôles, telles que le nom du rôle, la description, etc.
  3. Tableau des autorisations : stocke des informations de base sur les autorisations, telles que les noms des autorisations, les descriptions, etc.
  4. Table d'association rôle-permission (role_permission) : enregistre la relation correspondante entre les rôles et les autorisations.
  5. Table d'association utilisateur-rôle (user_role) : enregistre la relation correspondante entre les utilisateurs et les rôles.

Tout d'abord, créez le fichier de migration :

php artisan make:migration create_users_table
php artisan make:migration create_roles_table
php artisan make:migration create_permissions_table
php artisan make:migration create_role_permission_table
php artisan make:migration create_user_role_table
Copier après la connexion

Ensuite, écrivez la structure de la table dans le fichier de migration correspondant (le code est omis), et exécutez la commande de migration :

php artisan migrate
Copier après la connexion

Définissez la relation du modèle
Dans Laravel, nous Vous pouvez utiliser des modèles Eloquent pour définir des relations entre les tables de base de données. Tout d’abord, nous devons définir trois modèles : utilisateur, rôle et autorisation.

  1. Modèle utilisateur (Utilisateur)

    namespace App;
    
    use IlluminateDatabaseEloquentModel;
    
    class User extends Model
    {
     // 用户与角色的多对多关系
     public function roles()
     {
         return $this->belongsToMany('AppRole')->withTimestamps();
     }
    
     // 判断用户是否拥有某个角色
     public function hasRole($role)
     {
         if (is_string($role)) {
             return $this->roles->contains('name', $role);
         }
    
         return !! $role->intersect($this->roles)->count();
     }
    
     // 判断用户是否拥有某个权限
     public function hasPermission($permission)
     {
         return $this->hasRole($permission->roles);
     }
    }
    Copier après la connexion
  2. Modèle de rôle (Rôle)

    namespace App;
    
    use IlluminateDatabaseEloquentModel;
    
    class Role extends Model
    {
     // 角色与用户的多对多关系
     public function users()
     {
         return $this->belongsToMany('AppUser')->withTimestamps();
     }
    
     // 角色与权限的多对多关系
     public function permissions()
     {
         return $this->belongsToMany('AppPermission')->withTimestamps();
     }
    
     // 判断角色是否拥有某个权限
     public function hasPermission($permission)
     {
         if (is_string($permission)) {
             return $this->permissions->contains('name', $permission);
         }
    
         return !! $permission->intersect($this->permissions)->count();
     }
    }
    Copier après la connexion
  3. Modèle d'autorisation (Permission)

    namespace App;
    
    use IlluminateDatabaseEloquentModel;
    
    class Permission extends Model
    {
     // 权限与角色的多对多关系
     public function roles()
     {
         return $this->belongsToMany('AppRole');
     }
    }
    Copier après la connexion

4. Paramètres de middleware et de routage
Afin de mettre en œuvre le système de gestion des autorisations, nous pouvons utiliser un middleware pour intercepter et authentifier les demandes d'accès des utilisateurs. Tout d’abord, nous devons définir un middleware d’autorisation.

  1. Définir le middleware d'autorisation :

    namespace AppHttpMiddleware;
    
    use Closure;
    use IlluminateSupportFacadesAuth;
    
    class CheckPermission
    {
     public function handle($request, Closure $next, $permission)
     {
         $user = Auth::user();
         
         if ($user && $user->hasPermission($permission)) {
             return $next($request);
         }
         
         return redirect()->route('403'); // 没有权限则跳转到403页面
     }
    }
    Copier après la connexion
  2. Enregistrer le middleware d'autorisation :
    Enregistrer le middleware d'autorisation dans le tableau $routeMiddleware dans appHttpKernel.php : appHttpKernel.php中的$routeMiddleware数组中注册权限中间件:

    protected $routeMiddleware = [
     // ...
     'permission' => AppHttpMiddlewareCheckPermission::class,
    ];
    Copier après la connexion
  3. 关联中间件与路由:
    routesweb.php中定义需要权限控制的路由,并使用permission

    Route::get('/members', 'MemberController@index')->middleware('permission:member_view');
    Copier après la connexion

Associer middleware et routage :

Définissez les routes qui nécessitent un contrôle d'autorisation dans routesweb.php et utilisez le middleware permission :

namespace AppHttpControllers;

use IlluminateSupportFacadesAuth;

class MemberController extends Controller
{
 public function index()
 {
    if (Auth::user()->hasPermission('member_view')) {
         return view('members.index');
    }
    
    // 没有权限则跳转到403页面
    return redirect()->route('403');
 }
}
Copier après la connexion

  1. 5. vous pouvez utiliser l'exemple de code suivant pour authentifier l'identité de l'utilisateur et renvoyer la vue correspondante en fonction des autorisations.

  2. Méthodes dans le contrôleur :

    @if(Auth::user()->hasPermission('member_view'))
     <!-- 具有查看成员的权限,显示相关内容 -->
     <table>
         ...
     </table>
    @else
     <!-- 没有权限,显示无权限提示 -->
     <div>您没有查看成员的权限</div>
    @endif
    Copier après la connexion
    Code dans la vue :

    rrreee

    6. Résumé

    Grâce aux étapes ci-dessus, nous avons implémenté avec succès un système de gestion des autorisations simple et puissant dans Laravel. En définissant les rôles, les autorisations et les relations correspondantes, en utilisant un middleware pour intercepter les routes et en évaluant les autorisations dans les contrôleurs et les vues, nous pouvons obtenir un contrôle précis des autorisations d'accès des utilisateurs. J'espère que cet article pourra vous aider à mieux comprendre et appliquer les fonctions de gestion des autorisations dans Laravel.
    • Références :
    • Documentation officielle de Laravel (https://laravel.com/docs/8.x/)
    🎜Tutoriels de la série Laravel Beyond CRUD : Gestion des autorisations (https://laravelbestpractices.com/series/show/ laravel -au-delà de la crud/épisodes/9)🎜🎜

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comparaison des dernières versions de Laravel et CodeIgniter Comparaison des dernières versions de Laravel et CodeIgniter Jun 05, 2024 pm 05:29 PM

Les dernières versions de Laravel 9 et CodeIgniter 4 fournissent des fonctionnalités et des améliorations mises à jour. Laravel9 adopte l'architecture MVC et fournit des fonctions telles que la migration de bases de données, l'authentification et le moteur de modèles. CodeIgniter4 utilise l'architecture HMVC pour fournir le routage, l'ORM et la mise en cache. En termes de performances, le modèle de conception basé sur le fournisseur de services de Laravel9 et le framework léger de CodeIgniter4 lui confèrent d'excellentes performances. Dans les applications pratiques, Laravel9 convient aux projets complexes qui nécessitent de la flexibilité et des fonctions puissantes, tandis que CodeIgniter4 convient au développement rapide et aux petites applications.

Comment les capacités de traitement des données de Laravel et de CodeIgniter se comparent-elles ? Comment les capacités de traitement des données de Laravel et de CodeIgniter se comparent-elles ? Jun 01, 2024 pm 01:34 PM

Comparez les capacités de traitement des données de Laravel et CodeIgniter : ORM : Laravel utilise EloquentORM, qui fournit un mappage relationnel classe-objet, tandis que CodeIgniter utilise ActiveRecord pour représenter le modèle de base de données en tant que sous-classe de classes PHP. Générateur de requêtes : Laravel dispose d'une API de requêtes chaînées flexible, tandis que le générateur de requêtes de CodeIgniter est plus simple et basé sur des tableaux. Validation des données : Laravel fournit une classe Validator qui prend en charge les règles de validation personnalisées, tandis que CodeIgniter a moins de fonctions de validation intégrées et nécessite un codage manuel des règles personnalisées. Cas pratique : l'exemple d'enregistrement d'utilisateur montre Lar

Laravel - Commandes artisanales Laravel - Commandes artisanales Aug 27, 2024 am 10:51 AM

Laravel - Artisan Commands - Laravel 5.7 est livré avec une nouvelle façon de traiter et de tester de nouvelles commandes. Il inclut une nouvelle fonctionnalité de test des commandes artisanales et la démonstration est mentionnée ci-dessous ?

Lequel est le plus adapté aux débutants, Laravel ou CodeIgniter ? Lequel est le plus adapté aux débutants, Laravel ou CodeIgniter ? Jun 05, 2024 pm 07:50 PM

Pour les débutants, CodeIgniter a une courbe d'apprentissage plus douce et moins de fonctionnalités, mais couvre les besoins de base. Laravel offre un ensemble de fonctionnalités plus large mais a une courbe d'apprentissage légèrement plus raide. En termes de performances, Laravel et CodeIgniter fonctionnent bien. Laravel dispose d'une documentation plus complète et d'un support communautaire actif, tandis que CodeIgniter est plus simple, léger et possède de solides fonctionnalités de sécurité. Dans le cas pratique de la création d'une application de blog, EloquentORM de Laravel simplifie la manipulation des données, tandis que CodeIgniter nécessite une configuration plus manuelle.

Laravel vs CodeIgniter : quel framework est le meilleur pour les grands projets ? Laravel vs CodeIgniter : quel framework est le meilleur pour les grands projets ? Jun 04, 2024 am 09:09 AM

Lors du choix d'un framework pour de grands projets, Laravel et CodeIgniter ont chacun leurs propres avantages. Laravel est conçu pour les applications d'entreprise, offrant une conception modulaire, une injection de dépendances et un ensemble de fonctionnalités puissantes. CodeIgniter est un framework léger plus adapté aux projets de petite et moyenne taille, mettant l'accent sur la rapidité et la facilité d'utilisation. Pour les grands projets avec des exigences complexes et un grand nombre d'utilisateurs, la puissance et l'évolutivité de Laravel sont plus adaptées. Pour les projets simples ou les situations avec des ressources limitées, les capacités de développement légères et rapides de CodeIgniter sont plus idéales.

Questions et réponses sur la conception de l'architecture de microservices d'applications d'entreprise PHP Questions et réponses sur la conception de l'architecture de microservices d'applications d'entreprise PHP May 07, 2024 am 09:36 AM

L'architecture des microservices utilise des frameworks PHP (tels que Symfony et Laravel) pour implémenter des microservices et suit les principes RESTful et les formats de données standard pour concevoir des API. Les microservices communiquent via des files d'attente de messages, des requêtes HTTP ou gRPC et utilisent des outils tels que Prometheus et ELKStack pour la surveillance et le dépannage.

Laravel vs CodeIgniter : quel framework est le meilleur pour les petits projets ? Laravel vs CodeIgniter : quel framework est le meilleur pour les petits projets ? Jun 04, 2024 pm 05:29 PM

Pour les petits projets, Laravel convient aux projets plus importants qui nécessitent des fonctionnalités et une sécurité élevées. CodeIgniter convient aux très petits projets qui nécessitent légèreté et facilité d'utilisation.

Quel est le meilleur moteur de template, Laravel ou CodeIgniter ? Quel est le meilleur moteur de template, Laravel ou CodeIgniter ? Jun 03, 2024 am 11:30 AM

En comparant le moteur de modèles Blade de Laravel et le moteur de modèles Twig de CodeIgniter, choisissez en fonction des besoins du projet et de vos préférences personnelles : Blade est basé sur la syntaxe MVC, qui encourage une bonne organisation du code et un héritage de modèles. Twig est une bibliothèque tierce qui offre une syntaxe flexible, des filtres puissants, une prise en charge étendue et un bac à sable de sécurité.

See all articles