我需要 django 中 AbstractBaseUser 的 has_perm() 示例
Posted
技术标签:
【中文标题】我需要 django 中 AbstractBaseUser 的 has_perm() 示例【英文标题】:I need has_perm() example for AbstractBaseUser in django 【发布时间】:2021-11-03 10:23:04 【问题描述】:我有一个自定义用户模型,我需要向具有某些角色(用户模型中的字段)的用户授予权限,但我在 Internet 上找不到任何示例,所以我向任何拥有此权限的人询问示例以前做过。这是我的抽象用户模型供参考:
class User(AbstractBaseUser, PermissionsMixin):
class RoleChoices(models.TextChoices):
admin = 'Admin', _('Admin')
cashier = 'Cashier', _('Cashier')
waiter = 'Waiter', _('Waiter')
courier = 'Courier', _('Courier')
customer = 'Customer', _('Customer')
username = models.CharField(_('username'), unique=True, max_length=100)
name = models.CharField(_('name'), max_length=100)
surname = models.CharField(_('surname'), max_length=100)
phone_number = models.CharField(_('phone_number'), max_length=100, null=True, default='Invalid Phone Number')
role = models.CharField(max_length=50, choices=RoleChoices.choices, default=RoleChoices.customer)
active = models.BooleanField(default=True)
date_joined = models.DateTimeField(auto_now_add=True)
USERNAME_FIELD = 'username'
REQUIRED_FIELDS = ['name', 'surname']
class Meta:
ordering = ['date_joined', ]
def __str__(self):
return self.username
def has_perm(self, perm, obj=None):
return True
def has_module_perms(self, app_label):
return True
@property
def is_active(self):
return self.active
objects = CustomUserManager()
提前致谢,如有语法错误,敬请原谅。
【问题讨论】:
【参考方案1】:要为给定模型对象创建自定义权限,请使用Meta
类的permissions
属性。
class User(AbstractBaseUser, PermissionsMixin):
...
class Meta:
permissions = [
("change_role", "Can change the role of user"),
# Others customs permissions if needed
]
如果您现在想检查用户是否有权更改角色,那么:
.py 文件中的user.has_perm('app.change_role')
app 是定义模型的应用的名称。
在模板文件(.html)中
当前记录的用户权限已存储在 perms
模板变量中。如下使用:
% if perms.app_label.change_role %
<!-- Show whatever you need here -->
% endif %
注意:这需要启用以下上下文处理器:django.contrib.auth.context_processors.auth
另请注意,如果您以超级用户身份登录,perms.app_label.foobar
将始终为真,即使您拼错了权限名称。
另外,如果您想查看用户由于所属组而拥有的所有权限,请启动 Django shell...
user = User.objects.get(username='somename')
user.get_group_permissions()
如果您想添加视图级别权限
from django.contrib.auth.decorators import permission_required
from django.contrib.auth.decorators import login_required
# Only user with app_name.change_role can access this url
@permission_required('app_name.change_role')
# Also protect the view with authenticated user
@login_required(login_url='/accounts/login/')
def my_protected_view(request):
# Do your secrets things here
【讨论】:
首先,感谢您的详细回答,这对了解发生了什么有很大帮助。我在定义用户使用 has_perm() 或 has_perms() 的权限时遇到问题,我想使用角色字段来分配任何权限。 我想帮助你,但我不明白你的问题!目标是什么?简单 我想限制服务员和收银员用户访问一些可以更改数据库数据的页面。我只想为此授权管理员。 怎么样,我明白了。为此,您可以在模板中定义一些urls
链接,如下所示:% if user.is_staff % <a href="% url 'only_admin_url' %"></a> % endif %
。请注意,您可以使用 is_staff 来检查用户是否具有管理员权限或 is_superuser 是否拥有所有权限。 Django user model documentation
我用views level permissions更新了答案。以上是关于我需要 django 中 AbstractBaseUser 的 has_perm() 示例的主要内容,如果未能解决你的问题,请参考以下文章
我真的需要在 Django 模板中使用 % load static % 吗?
如果我想在 Django 模板中有条件地使用数据库数据,我需要做啥?
如果使用通用视图,是不是需要在 django 模板表单中填写动作属性