使用django自带的group表给角色分组

Posted louzi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用django自带的group表给角色分组相关的知识,希望对你有一定的参考价值。

导入django自带的用户基类和分组模型

from django.contrib.auth.models import AbstractUser, Group

创建模型

class DongYaoUser(AbstractUser):
name = models.CharField(max_length=32, verbose_name=‘姓名‘)
department = models.ManyToManyField(‘Role‘, verbose_name=‘职位‘)

class Meta:
verbose_name_plural = ‘员工管理‘

def __str__(self):
return self.name


class Role(models.Model):
name = models.CharField(max_length=32, verbose_name=‘职位名称‘)
#多对多关联group模型
groups = models.ManyToManyField(to=Group, verbose_name="权限组")

class Meta:
verbose_name_plural = ‘职位管理‘

def __str__(self):
return self.name

views.py

#从角色中取出该角色的所有权限组并去重
role_list = staff.role.all()
group_set = {group.id for role in role_list for group in role.groups.all()}
#给角色添加权限
staff.groups.add(*group_set)
 




























以上是关于使用django自带的group表给角色分组的主要内容,如果未能解决你的问题,请参考以下文章

Django ORM,group_by 按所有值分组

Django:对表单字段进行分组

Django 表单字段分组

自定义类实现原生SQL的GROUP_CONCAT的功能

django基于角色的权限控制

请教Django的User/Group/Permission管理