Maison développement back-end tutoriel php Contrôle d'accès basé sur les rôles d'autorisation Yii (RBAC)

Contrôle d'accès basé sur les rôles d'autorisation Yii (RBAC)

Jun 29, 2019 pm 05:49 PM
yii

Contrôle d'accès basé sur les rôles d'autorisation Yii (RBAC)

1 : Concepts de base

Un rôle est un ensemble d'autorisations (par exemple : créer des publications, modifier des publications). Un rôle peut être attribué à un ou plusieurs utilisateurs. Pour vérifier si un utilisateur dispose d'une autorisation spécifique, le système vérifie si le rôle contenant l'autorisation est attribué à l'utilisateur.

Vous pouvez utiliser une règle pour l'associer à un rôle ou une autorisation. Une règle est représentée par un morceau de code et l'exécution de la règle est effectuée lors de la vérification si un utilisateur remplit ce rôle ou cette autorisation. Par exemple, l'autorisation « modifier la publication » pourrait utiliser une règle qui vérifie si l'utilisateur est le créateur de la publication. Lors de la vérification des autorisations, si l'utilisateur n'est pas le créateur de la publication, alors il (elle) sera considéré comme n'ayant pas l'autorisation de « modifier les publications ».

Les rôles et les autorisations peuvent être organisés hiérarchiquement. Dans certains cas, un rôle peut être constitué d'autres rôles ou autorisations, qui à leur tour peuvent être constitués d'autres autorisations. Yii implémente une hiérarchie d'ordres locaux, qui contient des niveaux d'arborescence plus spécifiques. Un rôle peut contenir une autorisation, mais pas l'inverse. (Note du traducteur : on peut comprendre que les rôles sont en haut et les autorisations en bas. Si les autorisations sont rencontrées de haut en bas, les rôles ne peuvent pas apparaître plus bas)

Deux : Configurer RBAC

Au début Avant de définir les données d'autorisation et d'effectuer des contrôles d'accès, vous devez configurer le composant d'application yiibaseApplication::authManager. Yii fournit deux ensembles de gestionnaires d'autorisations : yiirbacPhpManager et yiirbacDbManager. Le premier utilise des scripts PHP pour stocker les données d'autorisation, tandis que le second utilise une base de données pour stocker les données d'autorisation. Si votre application ne nécessite pas une grande quantité de gestion dynamique des rôles et des autorisations, vous pouvez envisager d'utiliser l'ancien

1 : Utiliser yiirbacPhpManager

return [    // ...
    'components' => [        'authManager' => [            'class' => 'yii\rbac\PhpManager',
        ],        // ...
    ],
];
Copier après la connexion

Une fois la configuration terminée, vous pouvez utiliser Yii : :$app-> ;authManager pour accéder à authManager

yiirbacPhpManager enregistre les données RBAC dans des fichiers du répertoire @app/rbac par défaut. Si les données du niveau d'autorisation doivent être modifiées au moment de l'exécution, assurez-vous que le processus du serveur WEB dispose des autorisations en écriture pour le répertoire et les fichiers qu'il contient.

2 : Utilisez yiirbacDbManager

(1) Configurez yiirbacDbManager

return [    // ...
    'components' => [        'authManager' => [            'class' => 'yii\rbac\DbManager',            // uncomment if you want to cache RBAC items hierarchy
            // 'cache' => 'cache',
        ],        // ...
    ],
];
Copier après la connexion

Notez ici :

Si vous utilisez le modèle de base de Yii, ce qui précède Pour la configuration, vous devez le configurer à la fois dans les fichiers config/console.php et config/web.php. Si vous êtes un modèle avancé de Yii, vous n'avez besoin de le configurer qu'une seule fois dans le fichier common/config/main.php

.

(2) Générez les tables d'autorisation requises

Si vous utilisez yiirbacDbManager, vous devez générer 4 tables de base de données pour stocker les données d'autorisation (elles ont toutes des noms de table par défaut. Si vous devez modifier les noms de table, configurer yiirbacDbManager Modifier si nécessaire)

itemTable : Cette table stocke les entrées d'autorisation (Note du traducteur : rôles et autorisations). Le nom de la table par défaut est "auth_item" .
itemChildTable : Cette table stocke la relation hiérarchique des entrées autorisées. Le nom de table par défaut est "auth_item_child".
assignmentTable : Cette table stocke l'attribution des entrées d'autorisation aux utilisateurs. Le nom de la table par défaut est « auth_assignment ».
ruleTable : Cette table stocke les règles. Le nom de la table par défaut est « auth_rule ».

Exécuter

yii migrate --migrationPath=@yii/rbac/migrations

Dans le répertoire du projet, après avoir exécuté la commande ci-dessus, à ce fois que nous Les quatre tables mentionnées ci-dessus seront générées dans la base de données

Contrôle daccès basé sur les rôles dautorisation Yii (RBAC)

Si vous n'utilisez pas de commandes détaillées pour générer la base de données, vous pouvez ajouter le contenu de supplieryisoftyii2rbacmigrationsschema-mysql. sql Copiez-le dans la base de données et exécutez-le pour générer la table de données

Après avoir généré la table d'autorisations correspondante, nous pouvons utiliser Yii::$app->authManager pour accéder à authManager

Trois. : Établir les données d'autorisation

1 : Ajouter (créer) des autorisations (générer des données d'autorisation dans la table auth_item, le type est 2 indiquant les autorisations)

$auth = Yii::$app->authManager;// 添加 "createPost" 权限$createPost = $auth->createPermission('createPost');
$createPost->description = '创建了createPost权限';
$auth->add($createPost);
Copier après la connexion

2 : Créer un rôle (générer des données de rôle dans le table auth_item, le type est 1 représente le rôle)

$auth = Yii::$app->authManager;
$role = $auth->createRole('author');
$role->description = '创建了author角色';
$auth->add($role);
Copier après la connexion

3 : Accorder les autorisations au rôle

(1) Accorder les autorisations spécifiées au rôle

$auth = Yii::$app->authManager;
$createPost = $auth->createPermission('createPost');//创建权限对象
$role = $auth->createRole('author');//创建角色对象
$auth->addChild($role, $createPost); //添加对应关系(给author角色添加createPost权限)
Copier après la connexion

(2) Accorder tout autorisations du rôle au rôle spécifié

$auth = Yii::$app->authManager;
$role1 = $auth->createRole('author1');//创建角色对象
$role2 = $auth->createRole('author2');//创建权限对象
$auth->addChild($role1, $role2); //添加对应关系(给author1角色添加author2角色所有权限)
Copier après la connexion

4 : attribuer des rôles aux utilisateurs

$auth = Yii::$app->authManager;
$role = $auth->createRole('author');//创建角色对象$auth->assign($role, 1); #1是IdentityInterface::getId()返回的id,及用户表的id
Copier après la connexion

Quatre : vérifier les autorisations

\Yii::$app->user->can($action) #$action表示权限\Yii::$app->user->can('createPost') #判断用户是否具有createPost权限
Copier après la connexion

Obtenir le rôle de l'utilisateur

$auth = Yii::$app->authManager;
$roles = $auth->getRolesByUser($userId);
Copier après la connexion

Obtenez les autorisations de l'utilisateur

$auth = Yii::$app->authManager;
$roles = $auth->getPermissionsByUser($userId);
Copier après la connexion

Ce qui précède est une simple compréhension du contrôle d'accès basé sur les rôles (RBAC). Pour plus de détails, veuillez vous référer à la documentation officielle de Yii

.

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 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semaines 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)

Comment utiliser le framework PHP Yii pour développer un système de sauvegarde cloud hautement disponible Comment utiliser le framework PHP Yii pour développer un système de sauvegarde cloud hautement disponible Jun 27, 2023 am 09:04 AM

Avec le développement continu de la technologie du cloud computing, la sauvegarde des données est devenue quelque chose que chaque entreprise doit faire. Dans ce contexte, il est particulièrement important de développer un système de sauvegarde cloud hautement disponible. Le framework PHP Yii est un framework puissant qui peut aider les développeurs à créer rapidement des applications Web hautes performances. Ce qui suit explique comment utiliser le framework Yii pour développer un système de sauvegarde cloud hautement disponible. Conception du modèle de base de données Dans le framework Yii, le modèle de base de données est une partie très importante. Parce que le système de sauvegarde des données nécessite beaucoup de tables et de relations

Symfony vs Yii2 : quel framework est le meilleur pour développer des applications Web à grande échelle ? Symfony vs Yii2 : quel framework est le meilleur pour développer des applications Web à grande échelle ? Jun 19, 2023 am 10:57 AM

Alors que la demande d'applications Web continue de croître, les développeurs ont de plus en plus de choix dans le choix des frameworks de développement. Symfony et Yii2 sont deux frameworks PHP populaires. Ils ont tous deux des fonctions et des performances puissantes, mais face à la nécessité de développer des applications Web à grande échelle, quel framework est le plus adapté ? Nous procéderons ensuite à une analyse comparative de Symphony et Yii2 pour vous aider à faire un meilleur choix. Présentation de base Symphony est un framework d'application Web open source écrit en PHP et basé sur

Requête de données dans le framework Yii : accédez efficacement aux données Requête de données dans le framework Yii : accédez efficacement aux données Jun 21, 2023 am 11:22 AM

Le framework Yii est un framework d'application Web PHP open source qui fournit de nombreux outils et composants pour simplifier le processus de développement d'applications Web, dont la requête de données est l'un des composants importants. Dans le framework Yii, nous pouvons utiliser une syntaxe de type SQL pour accéder à la base de données afin d'interroger et de manipuler les données efficacement. Le générateur de requêtes du framework Yii comprend principalement les types suivants : requête ActiveRecord, requête QueryBuilder, requête de commande et requête SQL originale.

Comment utiliser le framework Yii3 en php ? Comment utiliser le framework Yii3 en php ? May 31, 2023 pm 10:42 PM

À mesure qu’Internet continue de se développer, la demande de développement d’applications Web augmente également. Pour les développeurs, le développement d'applications nécessite un cadre stable, efficace et puissant, qui peut améliorer l'efficacité du développement. Yii est un framework PHP hautes performances de premier plan qui offre des fonctionnalités riches et de bonnes performances. Yii3 est la version nouvelle génération du framework Yii, qui optimise davantage les performances et la qualité du code basé sur Yii2. Dans cet article, nous présenterons comment utiliser le framework Yii3 pour développer des applications PHP.

Yii2 vs Phalcon : quel framework est le meilleur pour développer des applications de rendu graphique ? Yii2 vs Phalcon : quel framework est le meilleur pour développer des applications de rendu graphique ? Jun 19, 2023 am 08:09 AM

À l’ère actuelle de l’information, le big data, l’intelligence artificielle, le cloud computing et d’autres technologies sont devenus au centre des préoccupations des grandes entreprises. Parmi ces technologies, la technologie de rendu des cartes graphiques, en tant que technologie de traitement graphique haute performance, fait l'objet de plus en plus d'attention. La technologie de rendu des cartes graphiques est largement utilisée dans le développement de jeux, les effets spéciaux de films et de télévision, la modélisation technique et d'autres domaines. Pour les développeurs, choisir un framework adapté à leurs projets est une décision très importante. Parmi les langages actuels, PHP est un langage très dynamique. Quelques excellents frameworks PHP comme Yii2, Ph.

Guide de programmation Yii2 : Comment exécuter le service Cron Guide de programmation Yii2 : Comment exécuter le service Cron Sep 01, 2023 pm 11:21 PM

Si vous demandez « Qu'est-ce que Yii ? », consultez mon tutoriel précédent : Introduction au framework Yii, qui passe en revue les avantages de Yii et décrit les nouveautés de Yii 2.0, publié en octobre 2014. Hmm> Dans cette série Programmation avec Yii2, je guiderai les lecteurs dans l'utilisation du framework Yii2PHP. Dans le didacticiel d'aujourd'hui, je vais partager avec vous comment tirer parti des fonctionnalités de la console Yii pour exécuter des tâches cron. Dans le passé, j'ai utilisé wget - une URL accessible sur le Web - dans une tâche cron pour exécuter mes tâches en arrière-plan. Cela soulève des problèmes de sécurité et entraîne des problèmes de performances. Alors que je discutais de certaines façons d'atténuer les risques dans notre série Sécurité pour les startups, j'avais espéré passer aux commandes pilotées par la console.

Développement PHP : utilisez Yii2 et GrapeJS pour implémenter un CMS back-end et une édition visuelle front-end Développement PHP : utilisez Yii2 et GrapeJS pour implémenter un CMS back-end et une édition visuelle front-end Jun 15, 2023 pm 11:48 PM

Dans le développement de logiciels modernes, créer un système de gestion de contenu (CMS) puissant n’est pas une tâche facile. Non seulement les développeurs doivent posséder des compétences et une expérience approfondies, mais ils doivent également utiliser les technologies et les outils les plus avancés pour optimiser leurs fonctionnalités et leurs performances. Cet article explique comment utiliser Yii2 et GrapeJS, deux logiciels open source populaires, pour implémenter un CMS back-end et une édition visuelle frontale. Yii2 est un framework PHPWeb populaire qui fournit des outils et des composants riches pour créer rapidement

Comment convertir des objets yii en tableaux ou directement au format json Comment convertir des objets yii en tableaux ou directement au format json Jan 08, 2021 am 10:13 AM

Framework Yii : cet article présente la méthode de Yii pour convertir des objets en tableaux ou les afficher directement au format json. Il a une certaine valeur de référence et j'espère qu'il pourra vous aider.

See all articles