详解python如何在django中为用户模型添加自定义权限

  

django自带的认证系统能够很好的实现如登录,登出,创建用户,创建超级用户,修改密码等复杂操作,并且实现了用户组,组权限,用户权限等复杂结构,使用自带的认证系统就能帮助我们实现自定义的权限系统达到权限控制的目的。

  

在django中默认情况下,syncdb运行时安装了django.contrib.auth,它会为每个模型创建默认权限,如foo.can_change, foo.can_delete和foo.can_add。要向模型添加自定义权限,可以添加类元:在模型下,并在其中定义权限,如此处所述

  

我的问题是,如果我要为用户模型添加自定义权限,该怎么办?像foo.can_view。我可以用下面的代码片段来实现,

        ct=ContentType.objects。get (app_label=吧矸菅橹ぁ蹦J?坝没А?   烫=Permission.objects。创建(代号=can_view, name='可以查看用户的,   content_type=ct)   perm.save ()   之前      

但是我想要一些可以很好地与syncdb一起玩的东西,例如我的自定义模型下的元类。我应该在类元中有这些:在UserProfile下,因为这是扩展用户模型的方式。但是是否正确的方式呢?不会把它绑定到UserProfile模型?

  

你可以这样做:

  

在Django应用的__init__ . py中添加:

        从django.db.models。信号导入post_syncdb   从django.contrib.contenttypes。模型导入ContentType   从django.contrib。身份验证模型作为auth_models导入   从django.contrib.auth。模型进口许可      #定义用户相关的权限   * * kwargs def add_user_permissions(发送方):   ct=ContentType.objects。get (app_label=吧矸菅橹ぁ蹦J?坝没А?   烫,=Permission.objects创建。get_or_create(代号=can_view, name='可以查看用户的,content_type=ct)   post_syncdb。连接(add_user_permissions,发送方=auth_models)      之前      

原文地址:http://stackoverflow.com/questions/7724265/how-to-add-custom-permission-to-the-user-model-in-django

  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

详解python如何在django中为用户模型添加自定义权限