将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实例分享:快速查找出被挂马的文件
Jun 08 Python
Python中index()和seek()的用法(详解)
Apr 27 Python
python 简单搭建阻塞式单进程,多进程,多线程服务的实例
Nov 01 Python
python的re正则表达式实例代码
Jan 24 Python
用Python解数独的方法示例
Oct 24 Python
Python 项目转化为so文件实例
Dec 23 Python
python如何调用字典的key
May 25 Python
Python爬虫自动化爬取b站实时弹幕实例方法
Jan 26 Python
提取视频中的音频 Python只需要三行代码!
May 10 Python
利用python Pandas实现批量拆分Excel与合并Excel
May 23 Python
Python中22个万用公式的小结
Jul 21 Python
Python多线程实用方法以及共享变量资源竞争问题
Apr 12 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的SimpleXML方法读写XML接口文件实例解析
2014/06/16 PHP
详解WordPress中分类函数wp_list_categories的使用
2016/01/04 PHP
jQuery实现鼠标点击弹出渐变层的方法
2015/07/09 Javascript
利用Chrome DevTools直接调试Node.js和JavaScript的方法详解(并行)
2017/02/16 Javascript
关于Promise 异步编程的实例讲解
2017/09/01 Javascript
Node.JS中快速扫描端口并发现局域网内的Web服务器地址(80)
2017/09/18 Javascript
BootStrap 标题设置跨行无效的解决方法
2017/10/25 Javascript
Angular实现的table表格排序功能完整示例
2017/12/22 Javascript
js 实现复选框只能选择一项的示例代码
2018/01/23 Javascript
layui+jquery支持IE8的表格分页方法
2019/09/28 jQuery
js实现自定义滚动条的示例
2020/10/27 Javascript
[02:08:58]2014 DOTA2国际邀请赛中国区预选赛 Ne VS CIS
2014/05/22 DOTA
Python中实现常量(Const)功能
2015/01/28 Python
Python中使用MELIAE分析程序内存占用实例
2015/02/18 Python
Python中处理字符串之endswith()方法的使用简介
2015/05/18 Python
基于Python数据可视化利器Matplotlib,绘图入门篇,Pyplot详解
2017/10/13 Python
Python Nose框架编写测试用例方法
2017/10/26 Python
深入浅析Python2.x和3.x版本的主要区别
2018/11/30 Python
python文件写入write()的操作
2019/05/14 Python
面向新手解析python Beautiful Soup基本用法
2020/07/11 Python
如何实现一个python函数装饰器(Decorator)
2020/10/12 Python
CSS3 3D位移translate效果实例介绍
2016/05/03 HTML / CSS
canvas 如何绘制线段的实现方法
2018/07/12 HTML / CSS
英国领先的隐形眼镜在线供应商:Lenstore.co.uk
2019/11/24 全球购物
全球异乡人的跨境社交电商平台:Kouhigh口嗨网
2020/07/24 全球购物
Linux操作面试题
2012/05/16 面试题
大学生入党自我鉴定
2013/10/31 职场文书
小学生防溺水广播稿
2014/01/12 职场文书
七年级地理教学反思
2014/01/26 职场文书
关于祖国的演讲稿
2014/05/04 职场文书
政治学专业毕业生求职信
2014/08/11 职场文书
领导班子四风问题对照检查材料
2014/09/27 职场文书
贷款收入证明格式
2015/06/24 职场文书
JDBC连接的六步实例代码(与mysql连接)
2021/05/12 MySQL
详解thinkphp的Auth类认证
2021/05/28 PHP
python scrapy简单模拟登录的代码分析
2021/07/21 Python