drf中使用jwt重写手机验证方法

自定义用户设置认证,因为jwt默认是用用户名验证请求到后端的,而往往很多注册是通过手机号来进行验证登录的, 需要重写认证方式。
1、在settings文件中加入AUTHENTICATION_BACKENDS 的配置。

AUTHENTICATION_BACKENDS = (
    'users.views.CustomBackend',
)

2、在users模块中的views文件中编写一个类。自定义用户验证一定要继承ModelBackend类。然后重写其中的authenticate的函数。

其中user = User.objects.get(Q(username=username)|Q(mobile=username))这表示用用户名或者手机号来验证。

from django.contrib.auth.backends import ModelBackend
from django.contrib.auth import get_user_model
from django.db.models import Q




# Create your views here.

User = get_user_model()


class CustomBackend(ModelBackend):
    """
    自定义用户验证
    """
    def authenticate(self, username=None, password=None, **kwargs):
        try:
            user = User.objects.get(Q(username=username)|Q(mobile=username))
            if user.check_password(password):
                return user
        except Exception as e:
            return None

jwt中其他配置:

# jwt 过期时间 在settings文件中
import datatime

    JWT_AUTH = {
        'JWT_EXPIRATION_DELTA': datetime.timedelta(seconds=300),   
         'JWT_AUTH_HEADER_PREFIX': 'JWT',
    }

#days=3,参数 时间

JWT_EXPIRATION_DELTA 设置时间

JWT_AUTH_HEADER_PREFIX 设置浏览器header

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值