前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >第一季 | ModelBackend 自定义用户验证,实现用户名、手机号、邮箱登录

第一季 | ModelBackend 自定义用户验证,实现用户名、手机号、邮箱登录

作者头像
小团子
发布2020-04-08 10:46:21
1.4K0
发布2020-04-08 10:46:21
举报
文章被收录于专栏:数据云团数据云团

Django REST框架构建Web API。Django网络应用开发的5项基础核心技术包括模型(Model)的设计,URL 的设计与配置,View(视图)的编写,Template(模板)的设计和Form(表单)的使用。

需要邮箱、手机号、用户名登录

可以自定义用户验证

Django 身份验证,ModelBackend 是 Django 使用的默认身份验证后端,由用户标识符和密码组成的凭据进行验证。在 Django 默认的用户模型,用户标识符是用户名,而自定义用户模型,由USERNAME_FIELD 指定的字段。

再来看下第一季都有哪些可以回顾和用得上的小技能

自定义用户验证

代码语言:javascript
复制
from django.db.models import Q
from django.contrib.auth import get_user_model
from django.contrib.auth.backends import ModelBackend

# Create your views here.
User = get_user_model()

class CustomBackend(ModelBackend):
    """
    自定义用户验证
    """
    def authenticate(self, request, username=None, password=None, **kwargs):
        if username is None:
            username = kwargs.get(User.USERNAME_FIELD)
        try:
            # 实现用户名、手机号、邮箱登录
            user = User.objects.get(Q(username=username) | Q(mobile=username) | Q(email=username))
            if user.check_password(password) and self.user_can_authenticate(user) and user.is_active:
                # 用户登录
                return user
        except User.DoesNotExist:
            return None

Django 在 settings.py 中用 “AUTHENTICATION_BACKENDS” 列表来测试认证。当调用 django.contrib.auth.authenticate() 时,Django 将尝试所有的认证后端。若第一个认证方法失败了,Django 将会继续尝试第二个,直到所有的都被尝试过。

默认情况下,AUTHENTICATION_BACKENDS 的设置为 django.contrib.auth.backends.ModelBackend,这是Django检查用户数据的基本认证方案。

自定义用户验证需要在 settings.py 文件的 AUTHENTICATION_BACKENDS 配置

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-04-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 数据云团 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
多因子身份认证
多因子身份认证(Multi-factor Authentication Service,MFAS)的目的是建立一个多层次的防御体系,通过结合两种或三种认证因子(基于记忆的/基于持有物的/基于生物特征的认证因子)验证访问者的身份,使系统或资源更加安全。攻击者即使破解单一因子(如口令、人脸),应用的安全依然可以得到保障。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档