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

作者:goldensun 时间:2022-05-09 20:33:15 

将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文档。

标签:Django
0
投稿

猜你喜欢

  • Python计算矩阵的和积的实例详解

    2021-06-06 10:09:34
  • 使用Python处理Excel表格的简单方法

    2023-12-07 08:05:04
  • 跟老齐学Python之坑爹的字符编码

    2021-07-13 06:07:38
  • Python中操作文件之write()方法的使用教程

    2023-12-29 06:06:13
  • python如何给内存和cpu使用量设置限制

    2021-03-04 00:43:00
  • Python在字符串中处理html和xml的方法

    2023-09-01 21:19:08
  • Windows8下安装Python的BeautifulSoup

    2022-05-30 15:03:06
  • python-字典dict和集合set

    2021-09-30 10:10:17
  • Python学习笔记之lambda表达式用法详解

    2022-01-28 15:39:37
  • 用JS找出字符串中出现次数最多的字母

    2007-11-12 13:40:00
  • next在python中返回迭代器的实例方法

    2022-10-28 12:35:41
  • jsp页面中获取servlet请求中的参数的办法详解

    2023-06-19 10:52:00
  • python快速编写单行注释多行注释的方法

    2022-06-04 07:06:54
  • CTF中的PHP特性函数解析之中篇

    2023-06-11 12:56:20
  • 10个顶级Python实用库推荐

    2023-08-27 17:41:46
  • Python基于staticmethod装饰器标示静态方法

    2022-11-07 07:25:11
  • Python实现求解最大公约数的五种方法总结

    2023-07-02 20:34:46
  • Mootools 1.2教程(13)——正则表达式

    2008-12-07 20:25:00
  • asp将数据库中的信息存储至XML文件中

    2007-09-19 12:54:00
  • 弹性+固宽布局

    2009-05-15 12:19:00
  • asp之家 网络编程 m.aspxhome.com