将Python的Django框架与认证系统整合的方法


Posted in Python onJuly 24, 2015

将Django与其他现有认证系统的用户名和密码或者认证方法进行整合是可以办到的。

例如,你所在的公司也许已经安装了LDAP,并且为每一个员工都存储了相应的用户名和密码。 如果用户在LDAP和基于Django的应用上拥有独立的账号,那么这时无论对于网络管理员还是用户自己来说,都是一件很令人头痛的事儿。

为了解决这样的问题,Django认证系统能让您以插件方式与其他认证资源进行交互。 您可以覆盖Diango默认的基于数据库的模式,您还可以使用默认的系统与其他系统进行交互。
指定认证后台

在后台,Django维护了一个用于检查认证的后台列表。 当某个人调用 django.contrib.auth.authenticate() (如14章中所述)时,Django会尝试对其认证后台进行遍历认证。 如果第一个认证方法失败,Django会尝试认证第二个,以此类推,一直到尝试完。

认证后台列表在AUTHENTICATION_BACKENDS设置中进行指定。 它应该是指向知道如何认证的Python类的Python路径的名字数组。 这些类可以在你Python路径的任何位置。

默认情况下,AUTHENTICATION_BACKENDS被设置为如下:

('django.contrib.auth.backends.ModelBackend',)

那就是检测Django用户数据库的基本认证模式。

AUTHENTICATION_BACKENDS的顺序很重要,如果用户名和密码在多个后台中都是有效的,那么Django将会在第一个正确匹配后停止进一步的处理。
编写认证后台

一个认证后台其实就是一个实现了如下两个方法的类: get_user(id) 和 authenticate(**credentials) 。

方法 get_user 需要一个参数 id ,这个 id 可以是用户名,数据库ID或者其他任何数值,该方法会返回一个 User 对象。

方法 authenticate 使用证书作为关键参数。 大多数情况下,该方法看起来如下:

class MyBackend(object):
  def authenticate(self, username=None, password=None):
    # Check the username/password and return a User.

但是有时候它也可以认证某个短语,例如:

class MyBackend(object):
  def authenticate(self, token=None):
    # Check the token and return a User.

每一个方法中, authenticate 都应该检测它所获取的证书,并且当证书有效时,返回一个匹配于该证书的 User 对象,如果证书无效那么返回 None 。 如果它们不合法,就返回None。

Django管理系统紧密连接于其自己后台数据库的 User 对象。 实现这个功能的最好办法就是为您的后台数据库(如LDAP目录,外部SQL数据库等)中的每个用户都创建一个对应的Django User对象。 您可以提前写一个脚本来完成这个工作,也可以在某个用户第一次登陆的时候在 authenticate 方法中进行实现。

以下是一个示例后台程序,该后台用于认证定义在 setting.py 文件中的username和password变量,并且在该用户第一次认证的时候创建一个相应的Django User 对象。

from django.conf import settings
from django.contrib.auth.models import User, check_password

class SettingsBackend(object):
  """
  Authenticate against the settings ADMIN_LOGIN and ADMIN_PASSWORD.

  Use the login name, and a hash of the password. For example:

  ADMIN_LOGIN = 'admin'
  ADMIN_PASSWORD = 'sha1$4e987$afbcf42e21bd417fb71db8c66b321e9fc33051de'
  """
  def authenticate(self, username=None, password=None):
    login_valid = (settings.ADMIN_LOGIN == username)
    pwd_valid = check_password(password, settings.ADMIN_PASSWORD)
    if login_valid and pwd_valid:
      try:
        user = User.objects.get(username=username)
      except User.DoesNotExist:
        # Create a new user. Note that we can set password
        # to anything, because it won't be checked; the password
        # from settings.py will.
        user = User(username=username, password='get from settings.py')
        user.is_staff = True
        user.is_superuser = True
        user.save()
      return user
    return None

  def get_user(self, user_id):
    try:
      return User.objects.get(pk=user_id)
    except User.DoesNotExist:
      return None

更多认证模块的后台, 参考Django文档。

Python 相关文章推荐
Python简单进程锁代码实例
Apr 27 Python
python读取文本中数据并转化为DataFrame的实例
Apr 10 Python
Python如何获得百度统计API的数据并发送邮件示例代码
Jan 27 Python
Python matplotlib学习笔记之坐标轴范围
Jun 28 Python
用Pytorch训练CNN(数据集MNIST,使用GPU的方法)
Aug 19 Python
如何解决tensorflow恢复模型的特定值时出错
Feb 06 Python
pandas中的数据去重处理的实现方法
Feb 10 Python
基于python3的socket聊天编程
Feb 17 Python
Pandas实现一列数据分隔为两列
May 18 Python
python 使用递归的方式实现语义图片分割功能
Jul 16 Python
Python监听剪切板实现方法代码实例
Nov 11 Python
Django框架中视图的用法
Jun 10 Python
Django与遗留的数据库整合的方法指南
Jul 24 #Python
简介Django中内置的一些中间件
Jul 24 #Python
Python字符串转换成浮点数函数分享
Jul 24 #Python
详解Python的Django框架中的中间件
Jul 24 #Python
浅谈Python的Django框架中的缓存控制
Jul 24 #Python
详解Django缓存处理中Vary头部的使用
Jul 24 #Python
解读Django框架中的低层次缓存API
Jul 24 #Python
You might like
php&java(一)
2006/10/09 PHP
PH P5.2至5.5、5.6的新增功能详解
2014/07/14 PHP
php函数实现判断是否移动端访问
2015/03/03 PHP
PHP入门教程之面向对象的特性分析(继承,多态,接口,抽象类,抽象方法等)
2016/09/11 PHP
PHP数组相加操作及与array_merge的区别浅析
2016/11/26 PHP
Thinkphp自定义生成缩略图尺寸的方法
2019/08/05 PHP
Javascript 函数中的参数使用分析
2010/03/27 Javascript
自定义一个jquery插件[鼠标悬浮时候 出现说明label]
2011/06/27 Javascript
jquery模拟SELECT下拉框取值效果
2013/10/23 Javascript
jQuery简单操作cookie的插件实例
2016/01/13 Javascript
jQuery Timelinr实现垂直水平时间轴插件(附源码下载)
2016/02/16 Javascript
jQuery实现的导航下拉菜单效果
2016/07/04 Javascript
详谈js中数组(array)和对象(object)的区别
2017/02/27 Javascript
js 数字、字符串、布尔值的转换方法(必看)
2017/04/07 Javascript
函数式编程入门实践(一)
2019/04/20 Javascript
jquery使用echarts实现有向图可视化功能示例
2019/11/25 jQuery
vue v-on:click传递动态参数的步骤
2020/09/11 Javascript
[02:43]DOTA2英雄基础教程 半人马战行者
2014/01/13 DOTA
Python利用字典将两个通讯录文本合并为一个文本实例
2018/01/16 Python
python中的set实现不重复的排序原理
2018/01/24 Python
Python3.5迭代器与生成器用法实例分析
2019/04/30 Python
对Python中一维向量和一维向量转置相乘的方法详解
2019/08/26 Python
使用Python的Turtle绘制哆啦A梦实例
2019/11/21 Python
解决Python命令行下退格,删除,方向键乱码(亲测有效)
2020/01/16 Python
Python运行异常管理解决方案
2020/03/09 Python
解决paramiko执行命令超时的问题
2020/04/16 Python
pycharm软件实现设置自动保存操作
2020/06/08 Python
详解css3使用transform出现字体模糊的解决办法
2020/10/16 HTML / CSS
电气自动化自荐信
2013/10/10 职场文书
亲子读书活动方案
2014/02/22 职场文书
安全生产责任书范本
2014/04/15 职场文书
乡镇党建工作汇报材料
2014/10/27 职场文书
检察院起诉意见书
2015/05/20 职场文书
mysql获取指定时间段中所有日期或月份的语句(不设存储过程,不加表)
2021/06/18 MySQL
MYSQL常用函数介绍
2022/05/05 MySQL
MySQL数据管理操作示例讲解
2022/12/24 MySQL