详解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使用mailbox打印电子邮件的方法
Apr 30 Python
Django中Model的使用方法教程
Mar 07 Python
创建pycharm的自定义python模板方法
May 23 Python
Selenium元素的常用操作方法分析
Aug 10 Python
python实现微信防撤回神器
Apr 29 Python
华为2019校招笔试题之处理字符串(python版)
Jun 25 Python
Flask框架学习笔记之消息提示与异常处理操作详解
Aug 15 Python
使用python 计算百分位数实现数据分箱代码
Mar 03 Python
Windows 下更改 jupyterlab 默认启动位置的教程详解
May 18 Python
如何解决python多种版本冲突问题
Oct 13 Python
python3排序的实例方法
Oct 20 Python
Python音乐爬虫完美绕过反爬
Aug 30 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
MYSQL环境变量设置方法
2007/01/15 PHP
php常用正则函数实例小结
2016/12/29 PHP
PHP实现二维数组去重功能示例
2017/01/12 PHP
PHP简单实现二维数组的矩阵转置操作示例
2017/11/24 PHP
小程序微信支付功能配置方法示例详解【基于thinkPHP】
2019/05/05 PHP
PHP设计模式(五)适配器模式Adapter实例详解【结构型】
2020/05/02 PHP
JS target与currentTarget区别说明
2011/08/28 Javascript
PHP开发者必须掌握的6个关键字
2014/04/14 Javascript
javascript去除空格方法小结
2015/05/21 Javascript
详解Bootstrap glyphicons字体图标
2016/01/04 Javascript
使用UrlConnection实现后台模拟http请求的简单实例
2017/01/04 Javascript
jquery表单提交带错误信息提示效果
2017/03/09 Javascript
es6学习之解构时应该注意的点
2017/08/29 Javascript
Js中将Long转换成日期格式的实现方法
2018/06/05 Javascript
vue.js指令v-for使用以及下标索引的获取
2019/01/31 Javascript
Node.js原生api搭建web服务器的方法步骤
2019/02/15 Javascript
vue-cli脚手架引入弹出层layer插件的几种方法
2019/06/24 Javascript
js基础之事件捕获与冒泡原理
2019/10/09 Javascript
vue+ts下对axios的封装实现
2020/02/18 Javascript
解决antd 下拉框 input [defaultValue] 的值的问题
2020/10/31 Javascript
JavaScript实现雪花飘落效果
2020/12/27 Javascript
python实现textrank关键词提取
2018/06/22 Python
jupyter 实现notebook中显示完整的行和列
2020/04/09 Python
Python如何输出警告信息
2020/07/30 Python
windows+vscode安装paddleOCR运行环境的步骤
2020/11/11 Python
HTML5 本地存储之如果没有数据库究竟会怎样
2013/04/25 HTML / CSS
美国葡萄酒网上商店:Martha Stewart Wine Co.
2019/03/17 全球购物
如何做好总经理助理
2013/11/12 职场文书
应届大学生的推荐信
2013/11/20 职场文书
学生党员的自我评价范文
2014/03/01 职场文书
个人社会实践自我鉴定
2014/03/24 职场文书
美国旅游签证工作证明
2014/10/14 职场文书
2014年幼儿园后勤工作总结
2014/11/10 职场文书
2014离婚协议书范文(3篇)
2014/11/29 职场文书
导游词之五台山
2019/10/11 职场文书
手写实现JS中的new
2021/11/07 Javascript