从数据库获取数据后,对数据进行清洗

目标:

  数据1,存放至session 中的数据

  数据2,显示至前端的菜单数据

清洗数据:

1.session存放的数据:(menu_leaf_dict)

2.前端菜单数据(rasult)

from app01 import models

# 取用户角色 uname  juese
data = models.Juese.objects.filter(utoj__u__uname='xguo') # 获取当前用户角色的权限 uname_juese quanxian_zsgc
# 数据去重 (.values(字段).distinct()) 排除不必要的数据 .exclude(qz__q__menu__isnull=True)
data2 = models.JtoQtoZ.objects.filter(j__in=data).exclude(qz__q__menu__isnull=True).values('qz__q__qxname','qz__q__url','qz__q__menu').distinct() # 获得菜单数据
data3 = models.Menu.objects.values("id", 'Mname', 'zgl').all() # for i in data2:
# print(i)
# {'qz__q__qxname': '行政管理', 'qz__q__url': '/xingzheng', 'qz__q__menu': 4}
# {'qz__q__qxname': '用户管理', 'qz__q__url': '/yonghu', 'qz__q__menu': 6} # for i in data3:
# print(i) # -------------------------------------------------------------------------------------- # 处理用户角色权限数据
# 格式:
# id list(dict)
# 4 [{'name': '行政管理', 'url': '/xingzheng', 'gid': 4, 'status': True, 'child': []}] menu_leaf_dict = {}
for i in data2:
i = {
'Mname': i['qz__q__qxname'],
'url': i['qz__q__url'],
'gid': i['qz__q__menu'],
'status': True,
'child': []
}
if i['gid'] in menu_leaf_dict:
menu_leaf_dict[i['gid']].append(i)
else:
menu_leaf_dict[i['gid']] = [i, ] # for i,j in menu_leaf_dict.items():
# print(i,j)
# # 4[{'name': '行政管理', 'url': '/xingzheng', 'gid': 4, 'status': True, 'child': []}]
# # 6[{'name': '用户管理', 'url': '/yonghu', 'gid': 6, 'status': True, 'child': []}] # -------------------------------------------------------------------------------------- # 处理菜单数据
# 格式:
# ID dict 形式
# 1 {'id': 1, 'Mname': '菜单1', 'zgl': None, 'child': [], 'status': False}
menu_dict = {}
for i in data3:
i['child'] = []
menu_dict[i['id']] = i
i['status'] = False # for i,j in menu_dict.items():
# print(i,j) # -------------------------------------------------------------------------------------- # 将用户角色权限数据 挂到 菜单数据中,并将被挂的菜单设置为 True
for i, j in menu_leaf_dict.items():
menu_dict[i]['child'] = j
# menu_dict[i]['status'] = True
zgl_id = i
# print(zgl_id)
while zgl_id:
menu_dict[zgl_id]['status'] = True
zgl_id = menu_dict[zgl_id]['zgl'] # for i,j in menu_dict.items():
# print(i, j)
'''
1 {'id': 1, 'Mname': '菜单1', 'zgl': None, 'child': [], 'status': False}
2 {'id': 2, 'Mname': '菜单2', 'zgl': None, 'child': [], 'status': False}
3 {'id': 3, 'Mname': '菜单3', 'zgl': None, 'child': [], 'status': False}
4 {'id': 4, 'Mname': '菜单1.1', 'zgl': 1, 'child': [{'name': '行政管理', 'url': '/xingzheng', 'gid': 4, 'status': True, 'child': []}], 'status': True}
5 {'id': 5, 'Mname': '菜单1.2', 'zgl': 1, 'child': [], 'status': False}
6 {'id': 6, 'Mname': '菜单1.1.1', 'zgl': 4, 'child': [{'name': '用户管理', 'url': '/yonghu', 'gid': 6, 'status': True, 'child': []}], 'status': True}
'''
# -------------------------------------------------------------------------------------- # 前端的菜单数据:
rasult = []
for i in menu_dict.values():
if i['zgl'] == None:
# if i['child'] != []:
rasult.append(i)
else:
menu_dict[i['zgl']]['child'].append(i) # for i in rasult:
# print(i) # --------------------------------------------------------------------------------------

rasult数据 清洗成前端可以显示的数据:

# # 递归函数(为递归显示菜单做准备)
def test(data_list):
response = ''
tpl = '''
<div class = 'item'>
<div class='title'>%s</div>
<div class='content'>%s</div>
</div>
'''
for i in data_list:
if not i['status']:
continue
elif 'url' in i:
response += "<a href='%s'>%s</a>" % (i['url'], i['Mname'])
else:
title = i['Mname']
i2 = test(i['child'])
response += tpl % (title, i2)
return response # 执行函数获取数据,利用递归函数
response = ''
tpl = '''
<div class = 'item'>
<div class='title'>%s</div>
<div class='content'>%s</div>
</div>
''' for i in rasult:
if not i['status']:
continue
title = i['Mname']
co = test(i['child'])
response += tpl % (title, co) # 最终菜单数据为 : response 数据

封装成class:

传递值:

user_data 用户数据
privilege_data 用户权限数据
menue_date 菜单数据

返回值:

return (menu_leaf_dict, response)
注释:return(用户权限的url,菜单显示的html)
class Privilege():

    def __init__(self, user_data, privilege_data, menue_date):
self.data = user_data
self.data2 = privilege_data
self.data3 = menue_date def data_clear(self):
menu_leaf_dict = {}
for i in self.data2:
i = {
'Mname': i['qz__q__qxname'],
'url': i['qz__q__url'],
'gid': i['qz__q__menu'],
'status': True,
'child': []
}
if i['gid'] in menu_leaf_dict:
menu_leaf_dict[i['gid']].append(i)
else:
menu_leaf_dict[i['gid']] = [i, ] menu_dict = {}
for i in self.data3:
i['child'] = []
menu_dict[i['id']] = i
i['status'] = False # 将用户角色权限数据 挂到 菜单数据中,并将被挂的菜单设置为 True
for i, j in menu_leaf_dict.items():
menu_dict[i]['child'] = j
menu_dict[i]['status'] = True
zgl_id = i
while zgl_id:
menu_dict[zgl_id]['status'] = True
zgl_id = menu_dict[zgl_id]['zgl'] rasult = []
for i in menu_dict.values():
if i['zgl'] == None:
rasult.append(i)
else:
menu_dict[i['zgl']]['child'].append(i) # # 递归函数
def test(data_list):
response = ''
tpl = '''
<div class = 'item'>
<div class='title'>%s</div>
<div class='content'>%s</div>
</div>
'''
for i in data_list:
if not i['status']:
continue
elif 'url' in i:
response += "<a href='%s'>%s</a>" % (i['url'], i['Mname'])
else:
title = i['Mname']
i2 = test(i['child'])
response += tpl % (title, i2)
return response # 执行函数获取数据
response = ''
tpl = '''
<div class = 'item'>
<div class='title'>%s</div>
<div class='content'>%s</div>
</div>
''' for i in rasult:
if not i['status']:
continue
title = i['Mname']
co = test(i['child'])
response += tpl % (title, co) return (menu_leaf_dict, response)

在views中应用:

from django.shortcuts import render,HttpResponse
from app01 import models
from static.privilage import Privilege # Create your views here. def index(requset):
# 取用户角色 uname juese
data = models.Juese.objects.filter(utoj__u__uname='xmei')
# 获取当前用户角色的权限 uname_juese quanxian_zsgc
# 数据去重 (.values(字段).distinct()) 排除不必要的数据 .exclude(qz__q__menu__isnull=True)
data2 = models.JtoQtoZ.objects.filter(j__in=data).exclude(qz__q__menu__isnull=True).values('qz__q__qxname', 'qz__q__url','qz__q__menu').distinct()
# 获得菜单数据
data3 = models.Menu.objects.values("id", 'Mname', 'zgl').all() test = Privilege(data,data2,data3)
a,b = test.data_clear() return render(requset, 'index.html', {'re': b})

Django学习手册 - 权限管理(二)的更多相关文章

  1. Django学习手册 - 权限管理(一)

    权限管理原理: 不同角色拥有不同的角色权限,所以能否访问的页面也就不相同. 通过控制URL使用户访问到不同的URL,从而达到权限控制的目的. 设计权限数据库 权限管理 from django.db i ...

  2. 转:JAVAWEB开发之权限管理(二)——shiro入门详解以及使用方法、shiro认证与shiro授权

    原文地址:JAVAWEB开发之权限管理(二)——shiro入门详解以及使用方法.shiro认证与shiro授权 以下是部分内容,具体见原文. shiro介绍 什么是shiro shiro是Apache ...

  3. 《Python学习手册》(二)

    <Python学习手册>(二) --类型和运算 数字 十六进制 八进制 二进制 0x 0o 0b hex() oct() bin() >>>int('10',2) 2 & ...

  4. 十二、基于Django实现RBAC权限管理

    一.RBAC概述 RBAC(Role-Based Access Control,基于角色的访问控制),通过角色绑定权限,然后给用户划分角色. 从企业的角度来说,基本上是按照角色来划分职能.比如,CEO ...

  5. SQL Server与Oracle对比学习:权限管理(二) 一些有趣的比喻

    http://blog.csdn.net/weiwenhp/article/details/8094739 目录(?)[-] SQL Server权限管理 login 与user的区别 角色role ...

  6. django 用户与权限管理

    django中使用content_type表进行存储app与model的关系.在permission表中设立了name(权限的名字,中英文均可)content_type_id(与content_typ ...

  7. MongoDB学习笔记—权限管理

    1.MongoDB权限介绍 a 上篇文章中,我们在Linux下配置了MongoDB环境并且将其设置为服务随机器启动而启动,那么接下来这篇文章我们就来简单说一下MongoDB下对登录用户权限的管理. b ...

  8. [转]Oracle学习笔记——权限管理

    本文转自:http://www.cnblogs.com/whgw/archive/2011/10/30.html 一.系统的默认用户 1)sys用户是超级用户,具有最高权限,具有sysdba角色,有c ...

  9. Django实现Rbac权限管理

    权限管理 权限管理是根据不同的用户有相应的权限功能,通常用到的权限管理理念Rbac. Rbac 基于角色的权限访问控制(Role-Based Access Control)作为传统访问控制(自主访问, ...

随机推荐

  1. TODO 软件测试68题

    白盒和黑盒的区别,你是怎么运用的?√  都是在debug的时候用的.没有实践过真正的白盒. 你是如何做测试分析?√  主要从功能的实现和性能问题上入手,功能的话以需求和实际使用的流程来分析,性能的话以 ...

  2. PHP三元运算符

    :条件 ? 结果1 : 结果2     <?php$a=10; $b=20;$c=$a>$b?($a-$b):($a+$b);//说明:如果变量a大于变量b则执行问号后面的,否则就执行:冒 ...

  3. 【Mac进销存管理软件】Daily Sales Pro Mac

        [简介] Daily Sales Mac版是Mac平台上的一款进销存软件,库存管理系统.Daily Sales Mac版是一款易于使用的进出库存管理软件,让您及时了解库存状况.销售收入.采购成 ...

  4. Mac上深色模式下的精美炫酷软件

    针对发布的 macOS Mojave 10.14 系统中,最大的改变就是引入了深色模式,尤其对技术开发人员来说非常实用,非常的酷! 深色模式使用一种较深的配色方案,这种配色作用于整个系统,包括 Mac ...

  5. python要点简要-一日精通python

    Python2.x是历史,Python3.x是这门语言的现在和未来.Python2和3大约90%的地方都很相似的. 1.注释 单行注释:在注释的前面输入#号,如下: # 这是一条注释 多行注释:使用三 ...

  6. 9、字符串转数字用int、因为input里面接受的全部是字符串

    #!/user/bin/python# -*- coding:utf-8 -*-num = int(input('请输入数字:'))if num == 1: print(666)elif num == ...

  7. docker swarm(当前官网示例)

    介绍 Docker Swarm 是 Docker 公司推出的官方容器集群平台,基于 Go 语言实现 作为容器集群管理器,Swarm 最大的优势之一就是 100% 支持标准的 Docker API.各种 ...

  8. python爬虫之Cookie

    由于http协议是无状态协议(假如登录成功,当访问该网站的其他网页时,登录状态消失),此时,需要将会话信息保存起来,通过cookie或者session的方式 cookie 将所有的回话信息保存在客户端 ...

  9. dubbo基础

    一.什么是dubbo,有什么用 dubbo是阿里巴巴开源的一个RPC框架,用于多个应用相互通信.使用dubbo需要安装一zookepper 二.dubbo的基本使用 1.构建一个maven的多模块项目 ...

  10. 如何优雅地使用Sublime Text3

    此文非原创,出处见文章结尾. 一.Sublime Text 3插件安装 优雅使用Sublime Text,插件则是不可缺少的存在:而插件的备份就显得非常的重要(譬如:各平台同步:更换系统/电脑,迅速使 ...