Django 权限认证(根据不同的用户,设置不同的显示和访问权限)
作者:hahei2020 发布时间:2023-09-18 04:07:30
标签:Django,权限认证
示意图:
html:(模态框等 html和js代码,参考:Django 创建/删除用户)
{# 权限管理 #}
<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;">勾选权限</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">联盟管理</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">订单系统</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">礼包奖励</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">服务器管理</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="重置权限?" >提 交</button>
</div>
js:
// 修改权限
function changePermission() {
var permissionList = $('input[name="permissionList"]:checked');
var permissions = '';
$.each(permissionList, function (index, value, array) {
if (index+1 == permissionList.length) { // 最后一位,不加逗号
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('未知错误!');
}
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
alert(errorThrown);
}
})
}
Django models 中,建立 模型: (这一步很重要!!!)
– 建立好后,记得用 makemigrations 和 migrate 同步一下!!
from django.db import models
class Permission(models.Model):
class Meta:
#权限信息,这里定义的权限的名字,后面是描述信息,描述信息是在django admin中显示权限用的
permissions = (
('views_slg_users_tem', '查看玩家管理'),
('views_slg_alliance_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', '查看管理员管理'),
)
建立好后,数据库表(auth_permission)类似于这样: (id 那一列,很重要!!我们后面添加权限要用到的!!)
后端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)
# 修改权限
@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] != '': # 不为空时
for index, value in enumerate(permissions):
permissions[index] = permissionsList[int(value)] # 将 数字 替换为 上面数组中的 字符串
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
# 修改权限
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] 数字为 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 # 修改成功
错误页面相关: (它是类似于:403, 404 等页面的汇总,也需要设置相关路由)
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路由:
'''总路由,路由分发地'''
from django.conf.urls import url, include
urlpatterns = [
url(r'^', include('slg.urls.slg.error')), # 错误页面 相关路由
]
'''子路由,这里进入具体的html页面'''
from django.conf.urls import url
from slg.views.slg import error
urlpatterns = [
url(r'^permissionDenied$', error.get_permissionDenied, name='get_permissionDenied'), # 403页面
]
正常页面的 权限设置:
base.html:(模板页面,所有页面都继承于此)
{% if 'slg.views_slg_users_tem' in perms %} {# 判断 是否 有访问权限,没有的话,就不显示该菜单 #}
<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视图 中的设置:
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') #权限装饰器
def get_users_tem(request):
perms = User.get_all_permissions(request.user) #获取 访问请求 用户的 所有权限
context = {"perms": perms}
return render(request, 'slg/slg_users_tem.html', context=context)
来源:https://blog.csdn.net/hahei2020/article/details/78427941


猜你喜欢
- 需求背景业务表tb_image部分数据如下所示,其中id唯一,image_no不唯一。image_no表示每个文件的编号,每个文件在业务系统
- 你不得不承认,今天网络发展之迅速,信息流动速度之快、量之大,是我们不曾考虑过的,但现在它就真真切切地摆在我们面前。如何接纳信息,怎么处理、消
- 一个程序要进行交互,就需要进行输入,进行输入→处理→输出的过程。所以就需要用到输入和输出功能。同样的,在Python中,怎么实现输入和输出?
- 本文实例为大家分享了pygame实现非图片按钮效果的具体代码,供大家参考,具体内容如下按钮类程序# -*- coding=utf-8 -*-
- TensorFlow是一款优秀的深度学习框架,支持多种常见的操作系统,例如Windows10,Mac Os等等,同时也支持运行在NVIDIA
- Office家族成员中,人们对于Access 2000的了解,往往只局限在它的操作界面中,对于数据库管理的功能仍只是停留在建立表、数据输入、
- 如果你在爬虫过程中有遇到“您的请求太过频繁,请稍后再试”,或者说代码完全正确,可是爬虫过程中突然就访问不了,那么恭喜你,你的爬虫被对方识破了
- 在网络可靠性中,一种较为经典且在实践中更为常用的可靠度计算便是二终端可靠度,即给定网络拓扑结构与边可靠度(假定节点完全可靠),计算网络中指定
- 最近在学习关于Python数据分析与挖掘方面的知识,在学习到Python数据分析工具方面时,需要安装一些第三方扩展库来增强Python的数据
- 项目开发中文件的读写是必不可少的下面来简单介绍一下文件的读读文件,首先我们要有文件那我首先自己创建了一个文本文件password.txt内容
- 什么叫做SPA单页应用单页Web应用 (single page web application,SPA) ,就是只有一张
- REPLACE用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。语法REPLACE ( ''strin
- 下载地址:https://dev.mysql.com/downloads/mysql/5.7.html#downloads上传到服务器rz
- 我就废话不多说了,直接上代码吧!>>> list1 = [1,2,3,4,4]>>> list2 = [
- 刚才帮一位朋友做跳转的时候做的,为了获取完整的url地址,还是花了那么点时间不过现在看来,原来是那么简单,没有网上那么多复杂的东东,相信一定
- 用采集程序的优点有:无须维护网站,因为采集程序中的数据来自其他网站,它将随着该网站的更新而更新;可以节省服务器资源,一般采集程序就几个文件,
- 本文实例讲述了Python集中化管理平台Ansible介绍与YAML。分享给大家供大家参考,具体如下:一 中文社区http://ansibl
- 下面是滚动条css代码参数介绍:scrollbar-3d-light-color 设置或检索滚动条亮边框颜色 scrollbar-highl
- python 文件操作seek() 和 telll() 自我解释file.seek()方法格式: seek(offset,whence=0)
- Session 对象 可以使用 Session 对象存储特定用户会话所需的信息。这样,当用户在应用程序的 Web 页之间跳转时,存储在 Se