详解Django中的权限和组以及消息


Posted in Python onJuly 23, 2015

在认证框架中还有其他的一些功能。 我们会在接下来的几个部分中进一步地了解它们。
权限

权限可以很方便地标识用户和用户组可以执行的操作。 它们被Django的admin管理站点所使用,你也可以在你自己的代码中使用它们。

Django的admin站点如下使用权限:

  •     只有设置了 add 权限的用户才能使用添加表单,添加对象的视图。
  •     只有设置了 change 权限的用户才能使用变更列表,变更表格,变更对象的视图。
  •     只有设置了 delete 权限的用户才能删除一个对象。

权限是根据每一个类型的对象而设置的,并不具体到对象的特定实例。 例如,我们可以允许Mary改变新故事,但是目前还不允许设置Mary只能改变自己创建的新故事,或者根据给定的状态,出版日期或者ID号来选择权限。

会自动为每一个Django模型创建三个基本权限:增加、改变和删除。 当你运行manage.py syncdb命令时,这些权限被添加到auth_permission数据库表中。

权限以 "<app>.<action>_<object_name>" 的形式出现。

就跟用户一样,权限也就是Django模型中的 django.contrib.auth.models 。因此如果你愿意,你也可以通过Django的数据库API直接操作权限。

组提供了一种通用的方式来让你按照一定的权限规则和其他标签将用户分类。 一个用户可以隶属于任何数量的组。

在一个组中的用户自动获得了赋予该组的权限。 例如, Site editors 组拥有 can_edit_home_page 权限,任何在该组中的用户都拥有这个权限。

组也可以通过给定一些用户特殊的标记,来扩展功能。 例如,你创建了一个 'Special users' 组,并且允许组中的用户访问站点的一些VIP部分,或者发送VIP的邮件消息。

和用户管理一样,admin接口是管理组的最简单的方法。 然而,组也就是Django模型 django.contrib.auth.models ,因此你可以使用Django的数据库API,在底层访问这些组。
消息

消息系统会为给定的用户接收消息。 每个消息都和一个 User 相关联。

在每个成功的操作以后,Django的admin管理接口就会使用消息机制。 例如,当你创建了一个对象,你会在admin页面的顶上看到 The object was created successfully 的消息。

你也可以使用相同的API在你自己的应用中排队接收和显示消息。 API非常地简单:

  •     要创建一条新的消息,使用 user.message_set.create(message='message_text') 。
  •     要获得/删除消息,使用 user.get_and_delete_messages() ,这会返回一个 Message 对象的列表,并且从队列中删除返回的项。

在例子视图中,系统在创建了播放单(playlist)以后,为用户保存了一条消息。

def create_playlist(request, songs):
  # Create the playlist with the given songs.
  # ...
  request.user.message_set.create(
    message="Your playlist was added successfully."
  )
  return render_to_response("playlists/create.html",
    context_instance=RequestContext(request))

当使用 RequestContext ,当前登录的用户以及他(她)的消息,就会以模板变量 {{ messages }} 出现在模板的context中。

{% if messages %}
<ul>
  {% for message in messages %}
  <li>{{ message }}</li>
  {% endfor %}
</ul>
{% endif %}

需要注意的是 RequestContext 会在后台调用 get_and_delete_messages ,因此即使你没有显示它们,它们也会被删除掉。

最后注意,这个消息框架只能服务于在用户数据库中存在的用户。 如果要向匿名用户发送消息,请直接使用会话框架。

Python 相关文章推荐
python动态网页批量爬取
Feb 14 Python
总结网络IO模型与select模型的Python实例讲解
Jun 27 Python
Python进阶篇之字典操作总结
Nov 16 Python
Python实现将一个大文件按段落分隔为多个小文件的简单操作方法
Apr 17 Python
Python入门_浅谈逻辑判断与运算符
May 16 Python
Python学习教程之常用的内置函数大全
Jul 14 Python
python多行字符串拼接使用小括号的方法
Mar 19 Python
opencv python统计及绘制直方图的方法
Jan 21 Python
pytorch中的卷积和池化计算方式详解
Jan 03 Python
使用Python实现Wake On Lan远程开机功能
Jan 22 Python
Python基于Socket实现简单聊天室
Feb 17 Python
Python scrapy爬取小说代码案例详解
Jul 09 Python
在Django的模板中使用认证数据的方法
Jul 23 #Python
在Django中管理Users和Permissions以及Groups的方法
Jul 23 #Python
Django中对通过测试的用户进行限制访问的方法
Jul 23 #Python
在Django中限制已登录用户的访问的方法
Jul 23 #Python
详解Django框架中用户的登录和退出的实现
Jul 23 #Python
在Django的session中使用User对象的方法
Jul 23 #Python
Django的session中对于用户验证的支持
Jul 23 #Python
You might like
php利用cookie实现访问次数统计代码
2011/05/19 PHP
jQuery 页面载入进度条实现代码
2009/02/08 Javascript
jQuery解决iframe高度自适应代码
2009/12/20 Javascript
javascript中的toFixed固定小数位数 简单实例分享
2013/07/12 Javascript
js实现大转盘抽奖游戏实例
2015/06/24 Javascript
JavaScript实现select添加option
2015/07/03 Javascript
浅谈jQuery 选择器和dom操作
2016/06/07 Javascript
Javascript获取background属性中url的值
2016/10/17 Javascript
javascript入门之string对象【新手必看】
2016/11/22 Javascript
Javascript基础回顾之(三) js面向对象
2017/01/31 Javascript
angular十大常见问题
2017/03/07 Javascript
BootStrap表单宽度设置方法
2017/03/10 Javascript
vue图片加载与显示默认图片实例代码
2017/03/16 Javascript
xmlplus组件设计系列之图标(ICON)(1)
2017/05/05 Javascript
浅谈通过JS拦截 pushState和replaceState事件
2017/07/21 Javascript
Vue.js实现按钮的动态绑定效果及实现代码
2017/08/21 Javascript
vue+swiper实现组件化开发的实例代码
2017/10/26 Javascript
详解微信小程序审核不通过的解决方法
2018/01/17 Javascript
webpack4 SCSS提取和懒加载的示例
2018/09/03 Javascript
bootstrap table实现合并单元格效果
2018/12/24 Javascript
JS中的算法与数据结构之队列(Queue)实例详解
2019/08/20 Javascript
Vue实现点击导航栏当前标签后变色功能
2020/08/19 Javascript
python检测是文件还是目录的方法
2015/07/03 Python
Python 实现文件的全备份和差异备份详解
2016/12/27 Python
Python自动化开发学习之三级菜单制作
2017/07/14 Python
Python 用Redis简单实现分布式爬虫的方法
2017/11/23 Python
python中使用print输出中文的方法
2018/07/16 Python
django 2.2和mysql使用的常见问题
2019/07/18 Python
伦敦一卡通:The London Pass
2018/11/30 全球购物
New Balance法国官方网站:购买鞋子和服装
2019/09/01 全球购物
亿阳信通股份有限公司笔试题(C#)
2016/03/04 面试题
汽车维修专业毕业生的求职信分享
2013/12/04 职场文书
运动会广播稿50字-100字
2014/10/11 职场文书
校运会班级霸气口号
2015/12/24 职场文书
2016年公务员六五普法心得体会
2016/01/21 职场文书
win11开机发生死循环重启怎么办?win11开机发生死循环重启解决方法
2022/08/05 数码科技