詳解python如何在django中為用戶模型添加自定義權限
django自帶的認證系統(tǒng)能夠很好的實現(xiàn)如登錄、登出、創(chuàng)建用戶、創(chuàng)建超級用戶、修改密碼等復雜操作,并且實現(xiàn)了用戶組、組權限、用戶權限等復雜結構,使用自帶的認證系統(tǒng)就能幫助我們實現(xiàn)自定義的權限系統(tǒng)達到權限控制的目的。
在django中默認情況下,syncdb運行時安裝了django.contrib.auth,它會為每個模型創(chuàng)建默認權限,如foo.can_change,foo.can_delete和foo.can_add.要向模型添加自定義權限,可以添加類Meta:在模型下,并在其中定義權限,如此處所述
我的問題是,如果我要為用戶模型添加自定義權限,該怎么辦?像foo.can_view.我可以用下面的代碼片段來實現(xiàn),
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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Python中根據時間自動創(chuàng)建文件夾的代碼實現(xiàn)
這篇文章主要介紹了Python中根據時間自動創(chuàng)建文件夾的代碼實現(xiàn),這樣的話給工作帶來極大的便利,方便桌面文件按時間存放,具體實例代碼跟隨小編一起看看吧2021-10-10
python+Matplotlib?繪制帶置信區(qū)間的折線圖
這篇文章主要介紹了python繪制帶置信區(qū)間的折線圖,在本文中,我們將使用?numpy?模塊生成隨機數據,并使用?matplotlib?庫實現(xiàn)數據可視化,需要的朋友可以參考下2023-05-05
python數據分析之聚類分析(cluster analysis)
聚類分析本身不是一個特定的算法,而是要解決的一般任務。它可以通過各種算法來實現(xiàn),這些算法在理解群集的構成以及如何有效地找到它們方面存在顯著差異。這篇文章主要介紹了python數據分析之聚類分析(cluster analysis),需要的朋友可以參考下2021-11-11

