您好,登錄后才能下訂單哦!
django自帶的認證系統能夠很好的實現如登錄、登出、創建用戶、創建超級用戶、修改密碼等復雜操作,并且實現了用戶組、組權限、用戶權限等復雜結構,使用自帶的認證系統就能幫助我們實現自定義的權限系統達到權限控制的目的。
在django中默認情況下,syncdb運行時安裝了django.contrib.auth,它會為每個模型創建默認權限,如foo.can_change,foo.can_delete和foo.can_add.要向模型添加自定義權限,可以添加類Meta:在模型下,并在其中定義權限,如此處所述
我的問題是,如果我要為用戶模型添加自定義權限,該怎么辦?像foo.can_view.我可以用下面的代碼片段來實現,
ct = ContentType.objects.get(app_label='auth', model='user') perm = Permission.objects.create(codename='can_view', name='Can View Users', content_type=ct) perm.save()
但是我想要一些可以很好地與syncdb一起玩的東西,例如我的自定義模型下的Meta類.我應該在類Meta中有這些:在UserProfile下,因為這是擴展用戶模型的方式.但是是否正確的方式呢?不會把它綁定到UserProfile模型?
你可以這樣做:
在Django應用的__init__.py中添加:
from django.db.models.signals import post_syncdb from django.contrib.contenttypes.models import ContentType from django.contrib.auth import models as auth_models from django.contrib.auth.models import Permission # custom user related permissions def add_user_permissions(sender, **kwargs): ct = ContentType.objects.get(app_label='auth', model='user') perm, created = Permission.objects.get_or_create(codename='can_view', name='Can View Users', content_type=ct) post_syncdb.connect(add_user_permissions, sender=auth_models)
原文地址:http://stackoverflow.com/questions/7724265/how-to-add-custom-permission-to-the-user-model-in-django
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。