一、什么是rbac
rbac翻译意思就是(Role-Based Access Contro)基于角色的权限控制
二、优势
1.将用户和权限的关系
2.易扩展,易于维护
比如张三李四需要用客户列表访问权限,如果上百个用户,单独分配权限会麻烦,如果单独放客户列表权限在销售角色里面,张三李四放到销售角色里就OK了
三、RBAC流程图
第一张:用户表
第二张:角色表
第三张表:用户表和角色表多对多的关系,一个用户可以有多个角色
第四张表:权限表
第五张表:权限表和角色表多对多的关系,多个权限可以放到一个角色里面
四、效果图
五、本章案例
背景:开发一个固定资产管理系统
实现功能:根据不同用户登陆分配不同权限,jack是CTO这个角色,CTO对所有页面有增删改查的权限,当jack登陆的时候,显示有增删改查的按钮。当登陆lucy,因为是COO的权限,有所有页面查询的权限,只能查看,无法添加修改删除。
1.在django中把rbac做成组件,到别的项目也可以直接拿来用
2.在项目中新创建一个名为rbac应用,创建命令startapp rbac
3.在rbac应用里mode.pyl写ORM,分别是账号表,角色表,权限表,权限组表
from django.db import models
# Create your models here.
class Account(models.Model):
name=models.CharField(max_length=32)
pwd=models.CharField(max_length=32)
roles=models.ManyToManyField(to="Role")
def __str__(self): return self.name
class Role(models.Model):
title=models.CharField(max_length=32)
permissions=models.ManyToManyField(to="Permission")
def __str__(self): return self.title
c