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

作者:goldensun 时间:2022-08-03 16:13:14 

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

权限可以很方便地标识用户和用户组可以执行的操作。 它们被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 ,因此即使你没有显示它们,它们也会被删除掉。

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

标签:Django
0
投稿

猜你喜欢

  • sql添加数据后返回受影响行数据

    2011-11-03 17:18:18
  • 三种Golang数组拷贝方式及性能分析详解

    2023-07-13 07:54:27
  • Python pyinotify日志监控系统处理日志的方法

    2023-12-11 08:57:37
  • 用python实现读取xlsx表格操作

    2022-11-26 17:08:19
  • Python利用FlashText算法实现替换字符串

    2023-05-17 06:18:11
  • Python代码需要缩进吗

    2022-05-07 18:21:15
  • 线上MySQL的自增id用尽怎么办

    2024-01-22 01:39:38
  • 简单实现js选项卡切换效果

    2024-05-03 15:05:24
  • Go语言二进制文件的读写操作

    2023-06-23 09:40:08
  • Python中的lambda和apply用法及说明

    2023-08-12 14:56:46
  • sql语句之数据操作介绍

    2024-01-22 18:09:39
  • 简单了解python调用其他脚本方法实例

    2022-12-07 08:53:36
  • HTML 5 胜出:XHTML2 宣告夭折

    2009-07-12 15:23:00
  • 全面了解CSS内置颜色(color)值

    2008-11-19 12:26:00
  • SQL行号排序和分页(SQL查询中插入行号 自定义分页的另类实现)

    2012-07-21 14:45:15
  • Python中使用第三方库xlutils来追加写入Excel文件示例

    2022-05-23 10:04:11
  • python深度学习tensorflow安装调试教程

    2021-06-28 23:03:51
  • Django框架基础模板标签与filter使用方法详解

    2022-10-25 18:14:43
  • 公网远程访问局域网SQL Server数据库

    2024-01-22 01:38:21
  • pycharm运行和调试不显示结果的解决方法

    2023-11-04 21:09:46
  • asp之家 网络编程 m.aspxhome.com