Django 權(quán)限認(rèn)證(根據(jù)不同的用戶,設(shè)置不同的顯示和訪問權(quán)限)
示意圖:

html:(模態(tài)框等 html和js代碼,參考:Django 創(chuàng)建/刪除用戶)
{# 權(quán)限管理 #}
<div id="permissionManageDiv" style="margin-left: 10px; display: none;">
<div>
<h4 style="margin-top: 15px;">選擇用戶</h4>
<hr style="margin-top: 5px;" />
<select name="usernamePermission" id="usernamePermission" class="selectpicker" data-live-search="true">
{% for user in users %}
<option value="{{ user.username }}">{{ user.username }}</option>
{% endfor %}
</select>
<hr />
</div>
<div>
<h4 style="margin-top: 15px;">勾選權(quán)限</h4>
<hr style="margin-top: 5px;" />
<div style="margin-bottom: 10px;">
<div class="input-group input-group-lg" style="float: left; margin-right: 10px;">
<span class="input-group-addon">玩家管理</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="0" />
</span>
</div>
<div class="input-group input-group-lg" style="float: left; margin-right: 10px;">
<span class="input-group-addon">聯(lián)盟管理</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="1" />
</span>
</div>
<div class="input-group input-group-lg" style="float: left; margin-right: 10px;">
<span class="input-group-addon">公告郵件</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="2" />
</span>
</div>
<div class="input-group input-group-lg" style="float: left; margin-right: 10px;">
<span class="input-group-addon">訂單系統(tǒng)</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="3" />
</span>
</div>
<div class="input-group input-group-lg" style="">
<span class="input-group-addon">禮包獎(jiǎng)勵(lì)</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="4" />
</span>
</div>
</div>
<div>
<div class="input-group input-group-lg" style="float: left; margin-right: 10px;">
<span class="input-group-addon">客服反饋</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="5" />
</span>
</div>
<div class="input-group input-group-lg" style="float: left; margin-right: 10px;">
<span class="input-group-addon">玩家日志</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="6" />
</span>
</div>
<div class="input-group input-group-lg" style="float: left; margin-right: 10px;">
<span class="input-group-addon">服務(wù)器管理</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="7" />
</span>
</div>
<div class="input-group input-group-lg">
<span class="input-group-addon">管理員管理</span>
<span class="input-group-addon">
<input type="checkbox" name="permissionList" value="8" />
</span>
</div>
</div>
</div>
<button type="button" id="changePermissionBtn" class="btn btn-default" style="width: 100px; margin-top: 15px;" data-toggle="modal" data-target="#alertTip" data-whatever="重置權(quán)限?" >提 交</button>
</div>
js:
// 修改權(quán)限
function changePermission() {
var permissionList = $('input[name="permissionList"]:checked');
var permissions = '';
$.each(permissionList, function (index, value, array) {
if (index+1 == permissionList.length) { // 最后一位,不加逗號(hào)
permissions += permissionList[index].value;
} else {
permissions += permissionList[index].value + ', ';
}
});
$.ajax({
url: '/changePermission',
type: 'POST',
data: {
username: $('#usernamePermission').val(),
permissions: permissions
},
success: function (data, textStatus) {
if (data == 1) {
alert('修改成功!');
window.location.href = 'index';
} else if (data == -1) {
alert('未知錯(cuò)誤!');
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(errorThrown);
}
})
}
Django models 中,建立 模型: (這一步很重要?。。。?
– 建立好后,記得用 makemigrations 和 migrate 同步一下??!
from django.db import models
class Permission(models.Model):
class Meta:
#權(quán)限信息,這里定義的權(quán)限的名字,后面是描述信息,描述信息是在django admin中顯示權(quán)限用的
permissions = (
('views_slg_users_tem', '查看玩家管理'),
('views_slg_alliance_tem', '查看聯(lián)盟管理'),
('views_slg_mail_notice_tem', '查看公告郵件'),
('views_slg_order_tem', '查看訂單系統(tǒng)'),
('views_slg_reward_tem', '查看禮包獎(jiǎng)勵(lì)'),
('views_slg_service_reply_tem', '查看客服反饋'),
('views_slg_user_log_tem', '查看玩家日志'),
('views_slg_server_tem', '查看服務(wù)器管理'),
('views_slg_manager_tem', '查看管理員管理'),
)
建立好后,數(shù)據(jù)庫表(auth_permission)類似于這樣: (id 那一列,很重要?。∥覀兒竺嫣砑訖?quán)限要用到的?。。?/p>

后端python–views視圖:
from django.contrib.auth.decorators import login_required, permission_required
from django.contrib.auth.models import User
from django.views.decorators.http import require_http_methods
from django.http import HttpResponse
from django.shortcuts import render
from slg.models.slg.slg_manager_tem import db_change_permission)
# 修改權(quán)限
@login_required(login_url='slg:login')
@require_http_methods(["POST"])
@permission_required('slg.views_slg_manager_tem', login_url='slg:get_permissionDenied')
def change_permission(request):
permissionsList = [
'views_slg_users_tem',
'views_slg_mail_notice_tem',
'views_slg_order_tem',
'views_slg_reward_tem',
'views_slg_service_reply_tem',
'views_slg_user_log_tem',
'views_slg_server_tem',
'views_slg_manager_tem'
]
username = request.POST['username']
permissions = request.POST['permissions'].split(', ')
if permissions[0] != '': # 不為空時(shí)
for index, value in enumerate(permissions):
permissions[index] = permissionsList[int(value)] # 將 數(shù)字 替換為 上面數(shù)組中的 字符串
print(permissions)
else:
permissions = []
changeResult = db_change_permission(username, permissions)
return HttpResponse(changeResult)
后端python–models視圖:
from django.contrib.auth.models import User
from django.contrib.auth import authenticate
from django.db.utils import IntegrityError
from . import db_models as db
# 修改權(quán)限
def db_change_permission(username, permissions):
try:
user = User.objects.get(username=username)
if permissions:
pers = []
for per in permissions:
db_per = db.AuthPermission.objects.filter(codename=per).values('id')[0]['id'] # 只把 id 取出來
pers.append(db_per)
#print(pers) # 形如: [147, 150, 152] 數(shù)字為 auth_permission 中的 id
user.user_permissions = pers # 這里,只能 加 id,加 codename 是不行的?。?!
else:
user.user_permissions.clear()
User.objects.get(username=username) # 刷新 緩存
#print(user.get_all_permissions())
except Exception:
return -1
else:
return 1 # 修改成功
錯(cuò)誤頁面相關(guān): (它是類似于:403, 404 等頁面的匯總,也需要設(shè)置相關(guān)路由)
permissionDenied.html:
<!DOCTYPE html>
<html lang="en">
{% load staticfiles %}
<head>
<meta charset="UTF-8">
<title>403</title>
</head>
<body>
<h1>403</h1>
<h2>You don't have enought permissions to this action!</h2>
</body>
</html>
view視圖:
from django.contrib.auth.decorators import login_required from django.views.decorators.http import require_http_methods from django.shortcuts import render # GET 渲染 403頁面 @login_required(login_url='slg:login') @require_http_methods(["GET", "POST"]) def get_permissionDenied(request): return render(request, 'slg/permissionDenied.html')
url路由:
'''總路由,路由分發(fā)地'''
from django.conf.urls import url, include
urlpatterns = [
url(r'^', include('slg.urls.slg.error')), # 錯(cuò)誤頁面 相關(guān)路由
]
'''子路由,這里進(jìn)入具體的html頁面''' from django.conf.urls import url from slg.views.slg import error urlpatterns = [ url(r'^permissionDenied$', error.get_permissionDenied, name='get_permissionDenied'), # 403頁面 ]
正常頁面的 權(quán)限設(shè)置:
base.html:(模板頁面,所有頁面都繼承于此)
{% if 'slg.views_slg_users_tem' in perms %} {# 判斷 是否 有訪問權(quán)限,沒有的話,就不顯示該菜單 #}
<li role="presentation" class="main-menu" id="top_one">
<a href="{% url 'slg:get_slg_users_tem' %}" rel="external nofollow" style="margin-left: 5px;"><span class="glyphicon glyphicon-fire"></span>玩家管理</a>
</li>
{% endif %}
其他 veiws視圖 中的設(shè)置:
from django.contrib.auth.decorators import login_required, permission_required
from django.contrib.auth.models import User
from django.views.decorators.http import require_http_methods
from django.shortcuts import render
# GET 渲染頁面 (其他的POST請求中,最好也加入 @permission_required 用來限制訪問)
@login_required(login_url='slg:login')
@require_http_methods(["GET"])
@permission_required('slg.views_slg_users_tem', login_url='slg:get_permissionDenied') #權(quán)限裝飾器
def get_users_tem(request):
perms = User.get_all_permissions(request.user) #獲取 訪問請求 用戶的 所有權(quán)限
context = {"perms": perms}
return render(request, 'slg/slg_users_tem.html', context=context)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Django自帶用戶認(rèn)證系統(tǒng)使用方法解析
- Django Auth用戶認(rèn)證組件實(shí)現(xiàn)代碼
- django基于存儲(chǔ)在前端的token用戶認(rèn)證解析
- Django用戶認(rèn)證系統(tǒng) 組與權(quán)限解析
- django rest framework 實(shí)現(xiàn)用戶登錄認(rèn)證詳解
- Django JWT Token RestfulAPI用戶認(rèn)證詳解
- Django實(shí)戰(zhàn)之用戶認(rèn)證(用戶登錄與注銷)
- Django用戶認(rèn)證系統(tǒng)如何實(shí)現(xiàn)自定義
相關(guān)文章
Python實(shí)現(xiàn)定時(shí)精度可調(diào)節(jié)的定時(shí)器
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)定時(shí)精度可調(diào)節(jié)的定時(shí)器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
如何使用Python的xml.etree.ElementTree模塊解析和操作 XML 數(shù)據(jù)
xml.etree.ElementTree是Python標(biāo)準(zhǔn)庫中用于解析和操作XML數(shù)據(jù)的模塊,無需安裝,支持解析、創(chuàng)建、修改和查詢XML數(shù)據(jù),本文介紹如何使用Python的xml.etree.ElementTree模塊解析和操作 XML 數(shù)據(jù),感興趣的朋友跟隨小編一起看看吧2025-01-01
解決python 兩個(gè)時(shí)間戳相減出現(xiàn)結(jié)果錯(cuò)誤的問題
這篇文章主要介紹了解決python 兩個(gè)時(shí)間戳相減出現(xiàn)結(jié)果錯(cuò)誤的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-03-03
python GUI庫圖形界面開發(fā)之PyQt5信號(hào)與槽多窗口數(shù)據(jù)傳遞詳細(xì)使用方法與實(shí)例
這篇文章主要介紹了python GUI庫圖形界面開發(fā)之PyQt5信號(hào)與槽多窗口數(shù)據(jù)傳遞詳細(xì)使用方法與實(shí)例,需要的朋友可以參考下2020-03-03
python之當(dāng)你發(fā)現(xiàn)QTimer不能用時(shí)的解決方法
今天小編就為大家分享一篇python之當(dāng)你發(fā)現(xiàn)QTimer不能用時(shí)的解決方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
淺談Python3中datetime不同時(shí)區(qū)轉(zhuǎn)換介紹與踩坑
最近的項(xiàng)目需要根據(jù)用戶所屬時(shí)區(qū)制定一些特定策略,學(xué)習(xí)、應(yīng)用了若干python3的時(shí)區(qū)轉(zhuǎn)換相關(guān)知識(shí),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
Python畫圖實(shí)現(xiàn)同一結(jié)點(diǎn)多個(gè)柱狀圖的示例
今天小編就為大家分享一篇Python畫圖實(shí)現(xiàn)同一結(jié)點(diǎn)多個(gè)柱狀圖的示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
基于Python實(shí)現(xiàn)一個(gè)多分類的Logistic回歸模型的代碼示例
在機(jī)器學(xué)習(xí)中,Logistic回歸是一種基本但非常有效的分類算法,它不僅可以用于二分類問題,還可以擴(kuò)展應(yīng)用于多分類問題,本文將詳細(xì)介紹如何使用Python實(shí)現(xiàn)一個(gè)多分類的Logistic回歸模型,并給出詳細(xì)的代碼示例,需要的朋友可以參考下2025-01-01
Python APScheduler執(zhí)行使用方法詳解
在本篇文章里小編給大家整理的是一篇關(guān)于Python APScheduler執(zhí)行使用方法的相關(guān)內(nèi)容,有興趣的朋友們可以學(xué)習(xí)下。2020-12-12

