Django自定义验证后端,实现利用用户名或电子邮箱地址账户无缝登陆

第一步:在自己的应用程序目录中新建文件,将其命名为authentication.py,并添加下列代码:

from django.contrib.auth.models import User


class EmailAuthBackend(object):
    def authenticate(self, request, username=None, password=None):
        try:
            user = User.objects.get(email=username)
            if user.check_password(password):
                return user
            return None
        except User.DoesNotExist:
            return None

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

第二步,编辑项目的settings.py文件并添加下列设置内容:

AUTHENTICATION_BACKENDS = [
    'django.contrib.auth.backends.ModelBackend',
    'account.authentication.EmailAuthBackend' # 刚刚自定义的认证后端,account为认证后端所在的应用名称
]

现在就既可以使用电子邮箱也可以使用用户名登陆系统了。

原理:  当使用django.contrib.auth的authenticate()函数时,Django将尝试将用户与定义于AUTHENTICATION_BACKENDS中的每个后端逐一验证,直至其中的某个后端成功地验证了用户。(只有全部后端验证均失效时,站点将不会对该用户授权)
Django提供了一种较为简单的方式定义自己的验证后端。这里,验证后端定义为一个类,并可提供以下两个方法:
1)authenticate()方法接受request对象以及用户凭证作为参数,同时须返回一个与此类凭证相匹配的user对象(若凭证有效);否则返回None。此处,request对象表示为一个HttpRequest对象;若未提供至authenticate()中,方法则返回None/
2)get_user()接受一个用户ID参数并返回一个user对象。


注:AUTHENTICATION_BACKENDS设置中列出来的后端顺序很重要。如果相同的凭证对多个后端均为有效,Django将在成功验证用户的第一个后端处停止。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值