웹 프론트엔드 JS 튜토리얼 Node.js Casbin에 대해 알아보기

Node.js Casbin에 대해 알아보기

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

Node.js Casbin에 대해 알아보기

【동영상 튜토리얼 추천: nodejs tutorial

Overview

Casbin은 강력하고 효율적인 오픈 소스 액세스 제어 프레임워크이며 권한 관리 메커니즘은 다중 액세스 제어 모델을 지원합니다.

카스빈이란 무엇인가요?

Casbin은 다음을 수행할 수 있습니다.

  • 사용자 정의 요청 형식을 지원합니다. 기본 요청 형식은 {주제, 개체, 작업}입니다.
  • 액세스 제어 모델 모델과 정책이라는 두 가지 핵심 개념을 가지고 있습니다.
  • RBAC에서는 주체뿐만 아니라 리소스도 역할을 가질 수 있는 다단계 역할 상속을 지원합니다.
  • 인증 정책의 제한을 받지 않고 모든 리소스에 액세스할 수 있는 루트 또는 관리자와 같은 슈퍼 사용자를 지원합니다.
  • keyMatch와 같은 다양한 내장 연산자를 지원하여 /foo/bar와 같은 경로 기반 리소스 관리를 용이하게 합니다. /foo*

Casbin은 다음을 수행할 수 없습니다.

  • 신원 인증 인증(즉, 사용자 이름과 비밀번호 확인), casbin은 접근 제어에 대해서만 책임을 집니다. 신원 인증을 담당하는 다른 특수 구성 요소가 있어야 하며, casbin은 이 두 가지가 함께 작동해야 합니다.
  • 사용자 목록 또는 역할 목록을 관리합니다. Casbin은 프로젝트 자체가 사용자 및 역할 목록을 관리하는 것이 더 적절하다고 믿습니다. 사용자는 일반적으로 자신의 비밀번호를 가지고 있지만 Casbin은 비밀번호를 저장하는 컨테이너로 설계되지 않았습니다. 대신 RBAC 체계에 사용자와 역할 간의 매핑 관계를 저장합니다.

Documentation

casbin.org/docs/en/overview

Installation

# NPMnpm install casbin --save# Yarnyarn add casbin
로그인 후 복사

시작하기

Casbin 시행 만들기 r에는 모델 파일과 정책 파일이 매개변수로 필요합니다. :

import { newEnforcer } from 'casbin';const enforcer = await newEnforcer('basic_model.conf', 'basic_policy.csv');
로그인 후 복사

파일 대신 DB의 정책을 사용하여 시행자를 초기화할 수도 있습니다. 자세한 내용은 어댑터를 참조하세요.

const sub = 'alice'; // 想要访问资源的用户。const obj = 'data1'; // 将要访问的资源。const act = 'read'; // 用户对资源执行的操作。const res = await enforcer.enforce(sub, obj, act);if (res) {
  // 允许 alice 读取数据1} else {
  // 拒绝请求,显示错误}
로그인 후 복사

정적 정책 파일 외에도 node-casbin는 런타임 시 권한 관리를 위한 API도 제공합니다. 예를 들어 다음과 같이 사용자에게 모든 역할을 할당할 수 있습니다.

const roles = await enforcer.getRolesForUser('alice');
로그인 후 복사

자세한 내용은 관리 API 및 RBAC API를 참조하세요. 사용 방법.

작동 방식

Casbin에서는 액세스 제어 모델이 PERM(Policy, Effect, Request, Matcher)을 기반으로 파일로 추상화됩니다. 따라서 프로젝트의 인증 메커니즘을 전환하거나 업그레이드하는 것은 구성을 수정하는 것만큼 간단합니다. 사용 가능한 모델을 결합하여 고유한 액세스 제어 모델을 사용자 정의할 수 있습니다. 예를 들어, 하나의 모델에 RBAC 역할과 ABAC 속성이 있고 정책 규칙 세트를 공유할 수 있습니다.

Casbin에서 가장 기본적이고 간단한 모델은 ACL입니다. ACL의 모델 CONF는 다음과 같습니다.

# 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
로그인 후 복사

ACL 모델의 예제 정책은 다음과 같습니다.

p, alice, data1, read
p, bob, data2, write
로그인 후 복사

즉,

  • alice는 데이터를 읽을 수 있습니다1
  • bob은 데이터를 쓸 수 있습니다2
    너무 긴 한 줄 구성의 경우 다음을 수행할 수 있습니다. 또한 줄 바꿈을 위해 끝에 '' 추가를 전달합니다:
# Matchers[matchers]m = r.sub == p.sub && r.obj == p.obj \ 
  && r.act == p.act
로그인 후 복사

또한 ABAC의 경우 Casbin golang 버전에서 다음(아직 jCasbin 및 Node-Casbin에서는 지원되지 않음) 작업을 시도할 수 있습니다:

# Matchers[matchers]m = r.obj == p.obj && r.act == p.act || r.obj in ('data2', 'data3')
로그인 후 복사

하지만 배열의 길이가 1보다 큰지 확인해야 합니다. 그렇지 않으면 패닉이 발생할 수 있습니다.

더 많은 작업을 보려면 govaluate를 확인하세요.

더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 소개를 방문하세요! !

위 내용은 Node.js Casbin에 대해 알아보기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Node의 메모리 제어에 관한 기사 Node의 메모리 제어에 관한 기사 Apr 26, 2023 pm 05:37 PM

Non-Blocking, Event-Driven 기반으로 구축된 Node 서비스는 메모리 소모가 적다는 장점이 있으며, 대규모 네트워크 요청을 처리하는데 매우 적합합니다. 대규모 요청을 전제로 '메모리 제어'와 관련된 문제를 고려해야 합니다. 1. V8의 가비지 수집 메커니즘과 메모리 제한 Js는 가비지 수집 기계에 의해 제어됩니다.

Node V8 엔진의 메모리와 GC에 대한 자세한 그래픽 설명 Node V8 엔진의 메모리와 GC에 대한 자세한 그래픽 설명 Mar 29, 2023 pm 06:02 PM

이 기사는 NodeJS V8 엔진의 메모리 및 가비지 수집기(GC)에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다.

Node의 파일 모듈에 대해 자세히 이야기해 보겠습니다. Node의 파일 모듈에 대해 자세히 이야기해 보겠습니다. Apr 24, 2023 pm 05:49 PM

파일 모듈은 파일 읽기/쓰기/열기/닫기/삭제 추가 등과 같은 기본 파일 작업을 캡슐화한 것입니다. 파일 모듈의 가장 큰 특징은 모든 메소드가 **동기** 및 ** 두 가지 버전을 제공한다는 것입니다. 비동기**, sync 접미사가 있는 메서드는 모두 동기화 메서드이고, 없는 메서드는 모두 이기종 메서드입니다.

최고의 Node.js Docker 이미지를 선택하는 방법에 대해 이야기해 볼까요? 최고의 Node.js Docker 이미지를 선택하는 방법에 대해 이야기해 볼까요? Dec 13, 2022 pm 08:00 PM

Node용 Docker 이미지를 선택하는 것은 사소한 문제처럼 보일 수 있지만 이미지의 크기와 잠재적인 취약점은 CI/CD 프로세스와 보안에 상당한 영향을 미칠 수 있습니다. 그렇다면 최고의 Node.js Docker 이미지를 어떻게 선택합니까?

Node.js 19가 공식적으로 출시되었습니다. Node.js의 6가지 주요 기능에 대해 이야기해 보겠습니다! Node.js 19가 공식적으로 출시되었습니다. Node.js의 6가지 주요 기능에 대해 이야기해 보겠습니다! Nov 16, 2022 pm 08:34 PM

Node 19가 정식 출시되었습니다. 이 글에서는 Node.js 19의 6가지 주요 기능에 대해 자세히 설명하겠습니다. 도움이 되셨으면 좋겠습니다!

Node.js의 GC(가비지 수집) 메커니즘에 대해 이야기해 보겠습니다. Node.js의 GC(가비지 수집) 메커니즘에 대해 이야기해 보겠습니다. Nov 29, 2022 pm 08:44 PM

Node.js는 GC(가비지 수집)를 어떻게 수행하나요? 다음 기사에서는 이에 대해 설명합니다.

Node의 이벤트 루프에 대해 이야기해 봅시다. Node의 이벤트 루프에 대해 이야기해 봅시다. Apr 11, 2023 pm 07:08 PM

이벤트 루프는 Node.js의 기본 부분이며 메인 스레드가 차단되지 않도록 하여 비동기 프로그래밍을 가능하게 합니다. 이벤트 루프를 이해하는 것은 효율적인 애플리케이션을 구축하는 데 중요합니다. 다음 기사는 Node.js의 이벤트 루프에 대한 심층적인 이해를 제공할 것입니다. 도움이 되기를 바랍니다!

노드가 npm 명령을 사용할 수 없으면 어떻게 해야 합니까? 노드가 npm 명령을 사용할 수 없으면 어떻게 해야 합니까? Feb 08, 2023 am 10:09 AM

노드가 npm 명령을 사용할 수 없는 이유는 환경 변수가 올바르게 구성되지 않았기 때문입니다. 해결 방법은 다음과 같습니다. 1. "시스템 속성"을 엽니다. 2. "환경 변수" -> "시스템 변수"를 찾은 다음 환경을 편집합니다. 3. nodejs 폴더의 위치를 ​​찾습니다. 4. "확인"을 클릭합니다.

See all articles