国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

django自帶的權限管理Permission用法說明

瀏覽:53日期:2024-10-08 09:08:51

前言

一些公司內部的CMS系統存在某些內容讓指定的用戶有權限訪問,這時候可以用django自帶的權限管理進行限制,比較方便。

缺點:django自帶的權限是針對model(模型)的,不能針對單條數據,要針對單條數據需要額外的操作。

默認的權限(add, change, delete, view)

django針對每個模型,生成了四個默認的權限(add, change, delete, view)。例如,我有一個model叫Log,那么這四個默認權限在數據庫的存儲格式為:

表auth_permission(注:id字段的值是隨便取的,使用python manage.py migrate的時候會自動生成)

id name content_type_id codename 1 Can add log 7 add_log 2 Can change log 7 change_log 3 Can delete log 7 delete_log 4 Can view log 7 view_log

字段解釋

id:自動生成的

name: 描述權限的的內容,無太大的實際作用

content_type_id:與django_content_type中的id字段對應

codename:權限表示值,換句話說用add_log來表示用戶對Log模型有新增權限。驗證權限的時候就是驗證這個值

那如果我的模型叫Student呢,把上面表中的log替換成student就行了。

name字段中Can add xx,Can change xx等都是固定的,只有xx是根據模型來的。

同理,codename字段也是一樣,add_xxx,change_xxx。

auth_permission表中content_type_id字段還沒有解釋,先來看下面這張表:

表django_content_type

id app_label model 1 admin logentry 3 auth group 2 auth permission 4 auth user 5 contenttypes contenttype 6 sessions session 7 test log

字段解釋

id:自增字段;auth_permission表的content_type_id字段就對應這個值

app_label:屬于哪個app包,上面的Log就是test app下的模型

model:模型名字

使用方法

在函數中驗證權限,使用user.has_perm

例如:我們有一個書店,有普通員工A(model User),現在需要去出版社訂購一批書(model Book),我們判斷這個人是否有權利添加(add_book)書籍。

user = User.objects.get(username=’A’)# has_permission是一個boolean,因為Book模型是放在test app下面的has_permission = user.has_perm(’test.add_book’)

為什么驗證權限的時候前面要加app名,很好理解啊,不同app有同樣名字的權限,到底是驗證哪個呢?

驗證函數是否有執行權限,使用@permission_required

@permission_requireddef function(): pass

permission_required有三個參數:

perm,描述權限的字符串,格式為:app名.權限。如'auth.add_user',“auth.delete_user”

login_url,如果沒有權限需要跳轉的url字符串,如'/login',“https://www.baidu.com”

raise_exception,boolean值,沒有權限是否觸發PermissionDenied異常,觸發異常則直接返回,不會跳轉到login_url指向的地址

在template上使用權限驗證

第一種寫法

首先,我們需要在app的根目錄下創建一個名為templatetags的包(IDEA會自動在包下創建__init__文件),接著在包里面創建一個文件my_tags.py,在my_tags.py里面定義一個過濾器has_permission,使用這個濾器對用戶進行權限驗證,它接收兩個參數:

user,當前登錄的用戶對象

perm,需要驗證的權限字符串

from django import templateregister = template.Library()@register.filterdef has_permisstion(user, perm): if user: return user.has_perm(perm) return False

接著,我們創建一個名為index.html的模板頁面,一定要記得加載標簽文件{% load my_tags %}。

<!DOCTYPE html>{% load my_tags %}<html lang='en'><head><meta charset='UTF-8'><title>首頁</title></head><body><p>后面的內容只有有權限的人才能看到,{% if request.user|has_permisstion:’test.add_department’ %}我有權限{% endif %}</p></body></html>

目錄結構:

django自帶的權限管理Permission用法說明

演示結果,我已經登錄過了,并且有權限了:

django自帶的權限管理Permission用法說明

第二種寫法

使用模板里面的全局變量perms,例如perms.test.add_department

{% if perms.應用名.權限標識 %} <!-- 這里是有權限才顯示的內容 -->{% endif %}

自定義權限

首先,我在test app的model文件中建立了一個Department模型,然后給他增加了一個自定義權限。

class Department(models.Model): name = models.CharField(null=True, max_length=20) user = models.ManyToManyField(User) one_user = models.ForeignKey(User, on_delete=models.SET_NULL, null=True, related_name=’one_user’) class Meta: # permissions是一個元組,記得每組權限后面加逗號,下面是一組權限 permissions = ( # (權限,權限描述), (’customize_permission’, ’This is my customize permission’), )

執行下面語句進行數據庫同步修改:

python manage.py makemigrationspython manage.py migrate

系統輸出,說明增加成功

>> Migrations for ’test’: testmigrations0003_auto_20200407_1645.py - Change Meta options on department

打開數據庫驗證,成功。

django自帶的權限管理Permission用法說明

然后,我們就能像前面一樣使用customize_permission這個權限了。

以上這篇django自帶的權限管理Permission用法說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Django
相關文章:
主站蜘蛛池模板: 在线视免费频观看韩国aaa | 黄色网址国产 | 免费ab| 91免费视频版 | 精品中文字幕在线 | 国产精品亚洲欧美日韩一区在线 | 国产欧美久久精品 | 日韩一级片播放 | 一级做a爱过程免费视频时看 | 久久欧美精品欧美久久欧美 | 欧美精品高清在线观看 | 男女免费观看在线爽爽爽视频 | 日韩手机看片福利精品 | 国产网站免费在线观看 | 亚洲国产成人久久精品图片 | 欧美一级特黄aa大片在线观看免费 | 久久亚洲国产午夜精品理论片 | 成人免费一级在线播放 | 91理论片午午伦夜理片久久 | 99久久精品免费观看国产 | 韩国毛片 免费 | 免费在线一级片 | 欧美成人精品不卡视频在线观看 | 国产手机视频 | 91刘亦菲精品福利在线 | 鸥美性生交xxxxx久久久 | 亚洲一级片免费看 | 日本一视频一区视频二区 | 中文在线日韩 | 国产在线毛片 | 综合亚洲欧美日韩一区二区 | 成年人网站在线观看视频 | 窝窝女人体国产午夜视频 | 精品久久香蕉国产线看观看亚洲 | 97视频在线观看免费播放 | 国产亚洲精品久久精品6 | 久久久久久久免费视频 | 久久草在线视频免费 | 欧美一级性视频 | 99九九精品免费视频观看 | 成年人免费网站视频 |