


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', ], // ... ], ];
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', ], // ... ], ];
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
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);
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);
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权限)
(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角色所有权限)
4 : attribuer des rôles aux utilisateurs
$auth = Yii::$app->authManager; $role = $auth->createRole('author');//创建角色对象$auth->assign($role, 1); #1是IdentityInterface::getId()返回的id,及用户表的id
Quatre : vérifier les autorisations
\Yii::$app->user->can($action) #$action表示权限\Yii::$app->user->can('createPost') #判断用户是否具有createPost权限
Obtenir le rôle de l'utilisateur
$auth = Yii::$app->authManager; $roles = $auth->getRolesByUser($userId);
Obtenez les autorisations de l'utilisateur
$auth = Yii::$app->authManager; $roles = $auth->getPermissionsByUser($userId);
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

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

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

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.

À 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.

À 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.

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.

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

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.
