170.分组-group、permission、user的操作
分组
1.Group.objects.create(group_name):创建分组。
2.group.permissions:某个分组上的权限。多对多关系。
(1)group.permissions.add():添加权限。
(2)group.permissions.remove():删除权限。
(3)group.permissions.clear():清除所有权限。
(4)user.get_group_permissions()获取用户所属组的权限。
3.user.groups.某个用户上的所有权限。多对多关系。
因为使用权限常用的相关操作,比如user.user_permissions.set(),user.user_permission.add(),或者是user.user.permissions.remove()等操作为每一个用户分别添加权限的话,就会比较麻烦。所以我们就可以根据各个职位权限的不同进行分组,并且为用户组进行添加权限。之后将用户添加到分组中就会拥有相应的组的权限了。如果我们还想为某些分组中的用户赋予一些组内其他用户不能有的权限时,就可以使用用户权限的相关操作分别为用户添加权限了。
1. 创建分组,为分组赋予权限,示例代码如下:
from django.contrib.auth.decorators import login_required, permission_required
from django.contrib.auth.models import Permission, ContentType, Group
from .models import Article
def operate_permission(request):
# 创建一个组
group = Group.objects.create(name='管理组')
<!--获取Article模型对应的表-->
content_type = ContentType.objects.get_for_model(Article)
<!--获取article表的用户对应的权限-->
permissions = Permission.objects.filter(content_type=content_type)
for permission in permissions:
print(permission)
# group.permissions.set(permissions)
<!--为用户组添加权限使用add()函数,需要注意的是,add()函数中必须传递一个个的权限,不能传递一个权限的列表-->
group.permissions.add(*permissions)
# group.save()
return HttpResponse('操作分组group: 创建分组,并且赋予权限!')
执行完成该操作之后,就可以在auth_group、auth_group_permissions表中看到我们添加的用户分组,并且为相应的分组添加的权限了。
2. 将user表中的第一个用户添加到分组中,示例代码如下:
def operate_permission(request):
# 2. 将user表中的第一个用户添加到管理分组中
user = User.objects.first()
group = Group.objects.filter(name='管理组').first()
# 将用户添加到分组中
user.groups.add(group)
# user.save()
return HttpResponse('操作分组group: 创建分组,并且赋予权限!')
执行完该操作之后,就可以在user_groups中找到添加的用户及分组了。
3. get_all_permissions()获取用户拥有的所有权限。示例代码如下:
def operate_permisssion(request):
# 3.可以通过get_all_permissions()获取用户拥有的所有权限
user = User.objects.first()
permissions = user.get_all_permissions()
for permission in permissions:
print(permission)
return HttpResponse('操作分组group: 创建分组,并且赋予权限!')
此时就可以在pycharm中的运行窗口,看到打印出的用户权限了。
login_logout.delete_article
login_logout.view_article
login_logout.change_article
login_logout.add_article
login_logout.black_article
如果你之前通过user.user_permissions.set()等操作已经为用户user赋予过权限的话,在user_permissions表中会有相应的对应关系。但是,需要注意的是,我们此时打印出的并不是通过具体的用户权限的操作为user添加的权限,而是通过查找我们的user属于哪个分组,分组又有什么样的权限,那么该user就有什么样的权限。可以将该用户在user_permissions表中对应的权限相关关系删除,之后再次运行项目,同样可以打印出user拥有的权限,此时,就可以去确定该user的权限来自分组对应的权限。
4. 可以通过has_perm()判断用户是否有该权限,示例代码如下:
def operate_permission(request):
# 4.通过has_perm()判断用户
user = User.objects.first()
if user.has_perm('login_logout.add_article'):
print("您拥有该权限")
else:
print("不好意思,您没有权限")
return HttpResponse('操作分组group: 创建分组,并且赋予权限!')
5. 同样判断用户是否登录还可以使用permissions_required装饰器判断,示例代码如下:
@permission_required(['login_logout.view_user','login_logout.add_user'], login_url= '/login_logout/', raise_exception=True)
<!--可以传递一个权限的列表进行判断-->
170.分组-group、permission、user的操作的更多相关文章
- MySQL数据分组Group By 和 Having
现有以下的学生信息表: 若果现在想计算每个班的平均年龄,使用where的操作如下: SELECT Cno AS 班级, AVG(Sage) AS 平均年龄 FROM stu ; 这样的话,有多少个班就 ...
- 第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all; Select 列 into 新表;字符串函数;日期函数
第17课-数据库开发及ado.net 聚合函数,模糊查询like,通配符.空值处理.order by排序.分组group by-having.类型转换-cast,Convert.union all; ...
- TFS二次开发10——分组(Group)和成员(Member)
TFS SDK 10 ——分组(Group)和成员(Member) 这篇来介绍怎样读取TFS服务器上的用户信息 首先TFS默认有如下分组(Group): SharePoint Web Applicat ...
- LeetCode 49: 字母异位词分组 Group Anagrams
LeetCode 49: 字母异位词分组 Group Anagrams 题目: 给定一个字符串数组,将字母异位词组合在一起.字母异位词指字母相同,但排列不同的字符串. Given an array o ...
- Oracle 表分组 group by和模糊查询like
分组group by写法 select 字段名 from 表名 group by 字段名 查询这个字段名里的种类分组后可以加聚合函数select 字段名,聚合函数 from 表名 group by 字 ...
- mysql分组GROUP BY常用sql
数据分组 GROUP BY GROUP BY可以根据一个或多个字段进行分组. 比如,根据prod_id分组: SELECT prod_id ,user_id FROM products GROUP B ...
- 【SQL】分组数据,过滤分组-group by , having
学习笔记,原文来自http://blog.csdn.net/robinjwong/article/details/24845125 创建分组 - GROUP BY 分组是在SELECT语句的GROUP ...
- sql-多表查询JOIN与分组GROUP BY
一.内部连接:两个表的关系是平等的,可以从两个表中获取数据.用ON表示连接条件 SELECT A.a,B.b FROM At AS A INNER JOINT Bt AS B ON A.m=B.n ...
- LINQ按多列分组(Group By)并计算总和(Sum) (转载)
来源:https://codedefault.com/2018/group-by-multiple-columns-and-sum-in-csharp .NET[C#]LINQ按多列分组(Group ...
随机推荐
- HDU_1035_水
http://acm.xidian.edu.cn/problem.php?id=1035 本来想用goto优化一下的,不知道什么情况,加了goto就wa了. #include<iostream& ...
- TCP、UDP 协议的区别
TCP 面向连接 可靠 传输形式:字节流 传输效率:慢 所需资源:多 首部字节:20-60 应用场景:要求通讯数据可靠(如文件传输.邮件传输) UPD 无连接 不可靠 传输形式:数据报文段 传输效率: ...
- 手把手教你Dubbo与SpringBoot常用两种方式整合
一.Dubbo整合SpringBoot的方式(1) 1)直奔主题,方式一: pom.xml中引入dubbo-starter依赖,在application.properties配置属性,使用@Servi ...
- python 中列表 元组 字典 集合的区别
先看图片解释 (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单.由于我们买一种东西可能不止一次,所以清单中是允许有重复 ...
- aws 社交媒体技术大会 部分总结
早上会议总结:. 1. 介绍了aws的应用,无技术知识点.略 2. 云原生: 就是一种在云中原生的一种技术 新常态:已经成为一种常态,基本都有的服务都可以部署在云端. 对 “互联网+” 和 “+互联 ...
- 大文件切割(split)
split提供两种方式对文件进行切割: 根据行数切割,通过-l参数指定需要切割的行数 根据大小切割,通过-b参数指定需要切割的大小 1.1 根据行数切割 如下以一个3.4G大小的日志文件做切割演示,每 ...
- 《python可以这样学》第一章
一.Python基础 查看Python版本 Python 3.7.3 (v3.7.3:ef4ec6ed12, Mar 25 2019, 22:22:05) [MSC v.1916 64 bit (AM ...
- Python字符串字母大小写变换
说明: 字符串就是一系列字符,在Python中用引号括起来的都是字符串,引号可以是单引号,也可以是双引号,比如:“This is a book.” ‘This is an apple.’ 接下来简单 ...
- 服务器字体导致NPE
服务器字体问题 服务器在windows下运行正常. 搬到Linux之后,注册页有个404??? HTTP Status 500 – Internal Server Error Type 异常报告 消息 ...
- C# 如何实现完整的INI文件读写类
作者: 魔法软糖 日期: 2020-02-27 引言 ************************************* .ini 文件是Initialization File的缩写,即配置文 ...