将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简单遍历字典及删除元素的方法
Sep 18 Python
Django实现自定义404,500页面教程
Mar 26 Python
Python通过调用有道翻译api实现翻译功能示例
Jul 19 Python
详解Python sys.argv使用方法
May 10 Python
给你一面国旗 教你用python画中国国旗
Sep 24 Python
利用pandas合并多个excel的方法示例
Oct 10 Python
python制作朋友圈九宫格图片
Nov 03 Python
使用Python将语音转换为文本的方法
Aug 10 Python
利用Python优雅的登录校园网
Oct 21 Python
Pycharm常用快捷键总结及配置方法
Nov 14 Python
python使用smtplib模块发送邮件
Dec 17 Python
Python使用openpyxl模块处理Excel文件
Jun 05 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 n个不重复的随机数生成代码
2009/06/23 PHP
基于PHP编程注意事项的小结
2013/04/27 PHP
利用PHP如何实现Socket服务器
2015/09/23 PHP
php求数组全排列,元素所有组合的方法总结
2017/03/14 PHP
document对象execCommand的command参数介绍
2006/08/01 Javascript
javascript(jquery)利用函数修改全局变量的代码
2009/11/02 Javascript
javascript下数值型比较难点说明
2010/06/07 Javascript
JS+CSS设置img在DIV中只显示Img垂直居中的部分
2013/10/24 Javascript
动态加载dtree.js树treeview(示例代码)
2013/12/17 Javascript
JavaScript前补零操作实例
2015/03/11 Javascript
javascript实现树形菜单的方法
2015/07/17 Javascript
JQuery通过AJAX从后台获取信息显示在表格上并支持行选中
2015/09/15 Javascript
js表单中选择框值的获取及表单的序列化
2015/12/17 Javascript
第七章之菜单按钮图标组件
2016/04/25 Javascript
JavaScript仿淘宝页面图片滚动加载及刷新回顶部的方法解析
2016/05/24 Javascript
轻松搞定jQuery+JSONP跨域请求的解决方案
2018/03/06 jQuery
jQuery实现为动态添加的元素绑定事件实例分析
2018/09/07 jQuery
node.js 基于cheerio的爬虫工具的实现(需要登录权限的爬虫工具)
2019/04/10 Javascript
深入解析Vue源码实例挂载与编译流程实现思路详解
2019/05/05 Javascript
VUE组件中的 Drawer 抽屉实现代码
2019/08/06 Javascript
node.js使用fs读取文件出错的解决方案
2019/10/23 Javascript
JavaScript正则表达式验证登录实例
2020/03/18 Javascript
从零学python系列之浅谈pickle模块封装和拆封数据对象的方法
2014/05/23 Python
Python实现删除文件中含“指定内容”的行示例
2017/06/09 Python
Python实现的端口扫描功能示例
2018/04/08 Python
pyspark.sql.DataFrame与pandas.DataFrame之间的相互转换实例
2018/08/02 Python
Django异步任务之Celery的基本使用
2019/03/23 Python
手把手教你pycharm专业版安装破解教程(linux版)
2019/09/26 Python
别名指示符是什么
2012/10/08 面试题
大学考试作弊检讨书
2014/01/30 职场文书
弘扬雷锋精神活动演讲稿
2014/03/04 职场文书
预备党员学习十八届三中全会精神思想汇报
2014/09/13 职场文书
党的群众路线教育实践活动对照检查材料(教师)
2014/09/24 职场文书
浅谈MySQL 亿级数据分页的优化
2021/06/15 MySQL
Python自动化测试PO模型封装过程详解
2021/06/22 Python
基于Redis zSet实现滑动窗口对短信进行防刷限流的问题
2022/02/12 Redis