Maison interface Web js tutoriel En savoir plus sur Node.js Casbin

En savoir plus sur Node.js Casbin

Aug 19, 2020 am 10:16 AM
node.js

En savoir plus sur Node.js Casbin

[Recommandation du didacticiel vidéo : Tutoriel nodejs ]

Présentation

Casbin est un framework de contrôle d'accès open source puissant et efficace. Son mécanisme de gestion des autorisations prend en charge plusieurs modèles de contrôle d'accès.

Qu'est-ce que Casbin ?

Casbin peut :

  • Prend en charge le format de demande personnalisé, le format de demande par défaut est {sujet, objet, action} .
  • Il comporte deux concepts fondamentaux : le modèle de contrôle d'accès et la politique.
  • Prend en charge l'héritage de rôles à plusieurs niveaux dans RBAC. Non seulement les sujets peuvent avoir des rôles, mais les ressources peuvent également avoir des rôles.
  • Prend en charge les super utilisateurs, tels que root ou administrateur, qui peuvent accéder à toutes les ressources sans être limités par les politiques d'autorisation.
  • prend en charge une variété d'opérateurs intégrés, tels que keyMatch, pour faciliter la gestion des ressources basées sur le chemin. Par exemple, /foo/bar peut être mappé à /foo*
<.>

Casbin ne peut pas :

    Authentification de l'identité (c'est-à-dire vérifier le nom d'utilisateur et le mot de passe de l'utilisateur), casbin est uniquement responsable du contrôle d'accès. Il devrait y avoir d'autres composants spécialisés responsables de l'authentification de l'identité, puis casbin devrait effectuer le contrôle d'accès. Les deux fonctionnent ensemble.
  • Gérer la liste d'utilisateurs ou la liste de rôles. Casbin estime qu'il est plus approprié que le projet lui-même gère les listes d'utilisateurs et de rôles. Les utilisateurs ont généralement leurs mots de passe, mais Casbin n'est pas conçu pour être un conteneur de stockage de mots de passe. Au lieu de cela, il stocke la relation de mappage entre les utilisateurs et les rôles dans le schéma RBAC.

Documentation

casbin.org/docs/en/overview

Installer
# NPMnpm install casbin --save# Yarnyarn add casbin
Copier après la connexion

Démarrer

La création de l'application Casbin nécessite un fichier de modèle et un fichier de stratégie comme paramètres :

import { newEnforcer } from 'casbin';const enforcer = await newEnforcer('basic_model.conf', 'basic_policy.csv');
Copier après la connexion
Vous pouvez également initialiser l'applicateur avec la stratégie dans la base de données au lieu du fichier, voir Adaptateurs pour plus de détails.

const sub = 'alice'; // 想要访问资源的用户。const obj = 'data1'; // 将要访问的资源。const act = 'read'; // 用户对资源执行的操作。const res = await enforcer.enforce(sub, obj, act);if (res) {
  // 允许 alice 读取数据1} else {
  // 拒绝请求,显示错误}
Copier après la connexion
En plus des fichiers de stratégie statiques,

fournit également des API pour la gestion des autorisations au moment de l'exécution. Par exemple, vous pouvez obtenir tous les rôles attribués à un utilisateur comme suit : node-casbin

const roles = await enforcer.getRolesForUser('alice');
Copier après la connexion
Voir Gestion API et API RBAC pour une utilisation accrue.

Comment ça marche

Dans Casbin, le modèle de contrôle d'accès est résumé dans un fichier basé sur PERM (Policy, Effect, Request, Matcher ) . Par conséquent, changer ou mettre à niveau le mécanisme d’autorisation d’un projet est aussi simple que de modifier la configuration. Vous pouvez personnaliser votre propre modèle de contrôle d'accès en combinant les modèles disponibles. Par exemple, vous pouvez avoir des rôles RBAC et des attributs ABAC dans un seul modèle et partager un ensemble de règles de stratégie.

Le modèle le plus basique et le plus simple de Casbin est ACL. Le modèle CONF dans ACL est :

# Request definition[request_definition]r = sub, obj, act

# Policy definition[policy_definition]p = sub, obj, act

# Policy effect[policy_effect]e = some(where (p.eft == allow))# Matchers[matchers]m = r.sub == p.sub && r.obj == p.obj && r.act == p.act
Copier après la connexion
L'exemple de politique du modèle ACL est le suivant :

p, alice, data1, read
p, bob, data2, write
Copier après la connexion
Cela signifie :

    alice peut lire les données1
  • bob can write data2
  • Pour une configuration trop longue sur une seule ligne, vous pouvez également couper la ligne en ajoutant '' à la fin :
# Matchers[matchers]m = r.sub == p.sub && r.obj == p.obj \ 
  && r.act == p.act
Copier après la connexion
De plus, pour ABAC, vous pouvez utiliser Version Casbin Golang Essayez l'opération suivante (pas encore prise en charge par jCasbin et Node-Casbin) :

# Matchers[matchers]m = r.obj == p.obj && r.act == p.act || r.obj in ('data2', 'data3')
Copier après la connexion
Mais vous devez vous assurer que la longueur du tableau est supérieure à

1, sinon ce sera provoquer la panique.

Pour plus d'opérations, vous pouvez consulter govaluate.

Pour plus de connaissances sur la programmation, veuillez visiter :

Introduction à la programmation ! !

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)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
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)

Un article pour parler du contrôle de la mémoire dans Node Un article pour parler du contrôle de la mémoire dans Node Apr 26, 2023 pm 05:37 PM

Le service Node construit sur une base non bloquante et piloté par les événements présente l'avantage d'une faible consommation de mémoire et est très adapté à la gestion de requêtes réseau massives. Dans le contexte de demandes massives, les questions liées au « contrôle de la mémoire » doivent être prises en compte. 1. Le mécanisme de récupération de place du V8 et les limitations de mémoire Js sont contrôlés par la machine de récupération de place

Explication graphique détaillée de la mémoire et du GC du moteur Node V8 Explication graphique détaillée de la mémoire et du GC du moteur Node V8 Mar 29, 2023 pm 06:02 PM

Cet article vous donnera une compréhension approfondie de la mémoire et du garbage collector (GC) du moteur NodeJS V8. J'espère qu'il vous sera utile !

Parlons de la façon de choisir la meilleure image Docker Node.js ? Parlons de la façon de choisir la meilleure image Docker Node.js ? Dec 13, 2022 pm 08:00 PM

Le choix d'une image Docker pour Node peut sembler trivial, mais la taille et les vulnérabilités potentielles de l'image peuvent avoir un impact significatif sur votre processus CI/CD et votre sécurité. Alors, comment choisir la meilleure image Docker Node.js ?

Parlons en profondeur du module File dans Node Parlons en profondeur du module File dans Node Apr 24, 2023 pm 05:49 PM

Le module de fichiers est une encapsulation des opérations de fichiers sous-jacentes, telles que l'ajout de lecture/écriture/ouverture/fermeture/suppression de fichiers, etc. La plus grande caractéristique du module de fichiers est que toutes les méthodes fournissent deux versions de **synchrone** et ** asynchrone**, with Les méthodes avec le suffixe sync sont toutes des méthodes de synchronisation, et celles qui n'en ont pas sont toutes des méthodes hétérogènes.

Node.js 19 est officiellement sorti, parlons de ses 6 fonctionnalités majeures ! Node.js 19 est officiellement sorti, parlons de ses 6 fonctionnalités majeures ! Nov 16, 2022 pm 08:34 PM

Node 19 est officiellement publié. Cet article vous donnera une explication détaillée des 6 fonctionnalités majeures de Node.js 19. J'espère qu'il vous sera utile !

Parlons du mécanisme GC (garbage collection) dans Node.js Parlons du mécanisme GC (garbage collection) dans Node.js Nov 29, 2022 pm 08:44 PM

Comment Node.js fait-il le GC (garbage collection) ? L’article suivant vous guidera à travers cela.

Parlons de la boucle d'événements dans Node Parlons de la boucle d'événements dans Node Apr 11, 2023 pm 07:08 PM

La boucle d'événements est un élément fondamental de Node.js et permet une programmation asynchrone en garantissant que le thread principal n'est pas bloqué. Comprendre la boucle d'événements est crucial pour créer des applications efficaces. L'article suivant vous donnera une compréhension approfondie de la boucle d'événements dans Node. J'espère qu'il vous sera utile !

Que dois-je faire si le nœud ne peut pas utiliser la commande npm ? Que dois-je faire si le nœud ne peut pas utiliser la commande npm ? Feb 08, 2023 am 10:09 AM

La raison pour laquelle le nœud ne peut pas utiliser la commande npm est que les variables d'environnement ne sont pas configurées correctement. La solution est la suivante : 1. Ouvrez "Propriétés système" ; 2. Recherchez "Variables d'environnement" -> "Variables système", puis modifiez l'environnement. variables ; 3. Recherchez l'emplacement du dossier nodejs ; 4. Cliquez sur "OK".

See all articles