Django使用otp(一次性密码)代替密码登录

时间:2019-05-26 10:23:08

标签: django login django-rest-framework django-rest-framework-simplejwt

我正在使用django-rest-framework为Web应用程序创建登录名(前端在React中),但是我只需要使用电话号码和otp进行登录,而无需密码。 otp发送到用户的电话号码。我正在使用自定义用户模型。我只是无法弄清楚如何覆盖内置的登录视图。我还尝试通过djangorestframework-simplejwt使用jwt令牌身份验证。

请帮我写下来。 models.py

from django.db import models
from django.contrib.auth.models import AbstractBaseUser
from django.contrib.auth.models import PermissionsMixin
from django.utils import timezone

from .managers import UserManager


class User(AbstractBaseUser, PermissionsMixin):
    phone = models.CharField(max_length=10, unique=True)
    full_name = models.CharField(max_length=30)
    business_name = models.CharField(max_length=30)
    is_fos = models.BooleanField(default=False)
    is_staff = models.BooleanField(default=False)
    is_active = models.BooleanField(default=True)
    date_joined = models.DateTimeField(default=timezone.now)

    USERNAME_FIELD = 'phone'
    REQUIRED_FIELDS = ['full_name', 'business_name']

    objects = UserManager()

    def __str__(self):
        return self.full_name

managers.py

from django.contrib.auth.base_user import BaseUserManager
from django.utils.translation import ugettext_lazy as _


class UserManager(BaseUserManager):
    """
    Custom user model manager where phone number is the unique identifiers
    for authentication instead of usernames.
    """
    def create_user(self, phone, full_name, business_name, **extra_fields):
        """
        Create and save a User with the given phone number.
        """
        if not phone:
            raise ValueError(_('Phone must be set'))
        user = self.model(phone=phone, full_name=full_name, business_name=business_name, **extra_fields)
        user.save()
        return user

    def create_superuser(self, phone, full_name, business_name, **extra_fields):
        """
        Create and save a SuperUser with the given phone number, name and buisness name.
        """
        extra_fields.setdefault('is_staff', True)
        extra_fields.setdefault('is_superuser', True)
        extra_fields.setdefault('is_active', True)

        if extra_fields.get('is_staff') is not True:
            raise ValueError(_('Superuser must have is_staff=True.'))
        if extra_fields.get('is_superuser') is not True:
            raise ValueError(_('Superuser must have is_superuser=True.'))
        return self.create_user(phone, full_name, business_name, **extra_fields)

0 个答案:

没有答案
相关问题