Django的session中对于用户验证的支持

作者:goldensun 时间:2021-07-21 07:19:16 


用户与Authentication

通过session,我们可以在多次浏览器请求中保持数据, 接下来的部分就是用session来处理用户登录了。 当然,不能仅凭用户的一面之词,我们就相信,所以我们需要认证。

当然了,Django 也提供了工具来处理这样的常见任务(就像其他常见任务一样)。 Django 用户认证系统处理用户帐号,组,权限以及基于cookie的用户会话。 这个系统一般被称为 auth/auth (认证与授权)系统。 这个系统的名称同时也表明了用户常见的两步处理。 我们需要

    验证 (认证) 用户是否是他所宣称的用户(一般通过查询数据库验证其用户名和密码)

    验证用户是否拥有执行某种操作的 授权 (通常会通过检查一个权限表来确认)

根据这些需求,Django 认证/授权 系统会包含以下的部分:

    用户 : 在网站注册的人

    权限 : 用于标识用户是否可以执行某种操作的二进制(yes/no)标志

    组 :一种可以将标记和权限应用于多个用户的常用方法

    Messages : 向用户显示队列式的系统消息的常用方法

如果你已经用了admin工具(详见第6章),就会看见这些工具的大部分。如果你在admin工具中编辑过用户或组,那么实际上你已经编辑过授权系统的数据库表了。
打开认证支持

像session工具一样,认证支持也是一个Django应用,放在 django.contrib 中,所以也需要安装。 与session系统相似,它也是缺省安装的,但如果它已经被删除了,通过以下步骤也能重新安装上:

    根据本章早前的部分确认已经安装了session 框架。 需要确认用户使用cookie,这样sesson 框架才能正常使用。

    将 'django.contrib.auth' 放在你的 INSTALLED_APPS 设置中,然后运行 manage.py syncdb以创建对应的数据库表。

    确认 SessionMiddleware 后面的 MIDDLEWARE_CLASSES 设置中包含 'django.contrib.auth.middleware.AuthenticationMiddleware' SessionMiddleware。

这样安装后,我们就可以在视图(view)的函数中处理user了。 在视图中存取users,主要用 request.user ;这个对象表示当前已登录的用户。 如果用户还没登录,这就是一个AnonymousUser对象(细节见下)。

你可以很容易地通过 is_authenticated() 方法来判断一个用户是否已经登录了:


if request.user.is_authenticated():
 # Do something for authenticated users.
else:
 # Do something for anonymous users.

标签:Django,session
0
投稿

猜你喜欢

  • jupyter notebook指定启动目录的方法

    2022-05-19 18:53:01
  • python实现LRU热点缓存及原理

    2022-01-08 01:26:15
  • django如何根据现有数据库表生成model详解

    2024-01-17 02:29:21
  • oracle跨库查询的方法

    2023-07-18 03:15:35
  • 小诀窍让你快速上手Dreamweaver

    2007-12-03 11:35:00
  • Python使用configparser读取ini配置文件

    2023-11-02 04:48:22
  • 深度学习入门之Pytorch 数据增强的实现

    2021-04-05 22:26:07
  • 网页广告 Banner 设计图文手册

    2007-10-18 19:56:00
  • asp显示左边的n个字符自动识别汉字的函数

    2007-09-13 12:16:00
  • Python机器学习NLP自然语言处理基本操作词向量模型

    2022-01-16 10:33:42
  • Python实现简单http服务器

    2022-02-04 03:55:01
  • 客户体验

    2008-12-11 13:58:00
  • windows下Git安装教程(图文)

    2022-12-24 06:09:40
  • sql 查询记录数结果集某个区间内记录

    2023-07-09 08:25:01
  • 解决python中set与dict的无序问题

    2021-02-24 14:50:31
  • Python Pandas高级教程之时间处理

    2021-08-12 14:04:49
  • 使用python接入微信聊天机器人

    2022-04-08 10:07:23
  • 解读python中的类型提示(type hint)

    2023-07-15 20:16:27
  • NopCommerce架构分析之(四)基于路由实现灵活的插件机制

    2024-05-13 09:14:51
  • python2.7的flask框架之引用js&css等静态文件的实现方法

    2022-05-04 12:09:27
  • asp之家 网络编程 m.aspxhome.com