权限管理 --- RBAC简单实现

本文介绍了基于角色的访问控制(RBAC)模型,并详细讲述了在Django中如何设计表、自定义访问权限以及进行接口测试,实现‘用户-角色-权限’的授权模型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、RBAC模型

  • RBAC模型(Role-Based Access Control:基于角色的访问控制)
  • 就是用户通过角色与权限进行关联
  • 简单的说,一个用户拥有若干角色,每个角色拥有若干权限
  • 这样,就构成了**“用户-角色-权限”**的授权模型
  • 在这种模型中,用户与角色之间,角色与权限之间,一般都是多对多关系

在这里插入图片描述

2、表设计

from django.db import models
from django.contrib.auth.models import AbstractUser
from utils.MyBaseModel import Base


# Create your models here.
# 角色表
class Role(models.Model):
    name = models.CharField('角色名称', max_length=32, unique=True)

    class Meta:
        db_table = 'tb_role'


# AbstractUser是django用户组件里的用户模型类,继承以后对原来的模型类进行改写
# 用户表
class User(AbstractUser):
    phone = models.CharField('手机号', max_length=20, null=True)
    img = models.ImageField(max_length=256, null=True)
    nick_name = models.CharField('昵称', max_length=20, null=True)
    address = models
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值