0

什么是最好的(最简单?)的方式,使之成为需要有一个电子邮件只为用户注册,而不是使用户名要求在Django的REST的身份验证框架?最佳实践

例如,我需要编写一个新的用户序列化程序吗?是否有一个标志设置,我可以将True或False设置为关闭或取决于此要求?

感谢

回答

0

你需要编写自己的AbstractUserBaseUserManager类。幸运的it's pretty simple,加入这样的事情你的应用程序的模型:

from django.contrib.auth.models import AbstractBaseUser, BaseUserManager 
from django.db import models 

class Account(AbstractBaseUser): 
    email = models.EmailField(unique=True) 
    username = models.CharField(max_length=40, unique=True, blank=True) 

    first_name = models.CharField(max_length=40, blank=True) 
    last_name = models.CharField(max_length=40, blank=True) 

    is_admin = models.BooleanField(default=False) 

    created_at = models.DateTimeField(auto_now_add=True) 
    updated_at = models.DateTimeField(auto_now=True) 

    objects = AccountManager() 

    # This tells Django that this field is absolutely important... 
    USERNAME_FIELD = 'email' 
    # ...and username is now optional because it doesn't show up here! 
    REQUIRED_FIELDS = [] 

    def __unicode__(self): 
     return self.email 

    def get_full_name(self): 
     return ' '.join([self.first_name, self.last_name]) 

    def get_short_name(self): 
     return self.first_name 

class AccountManager(BaseUserManager): 
    def create_user(self, email, password=None): 
     if not email: 
      raise ValueError('User must provide an e-mail address') 

     account = self.model(
      email=self.normalize_email(email) 
     ) 

     account.set_password(password) 
     account.save() 

     return account 

    def create_superuser(self, email, password=None): 
     account = self.create_user(email, password) 

     account.is_admin = True 
     account.save() 

     return account 

接下来,告诉Django,该模型是你项目的User类。以下添加到您的settings.py文件:

AUTH_USER_MODEL = 'apiapp.Account' 

一旦这样做了,只是迁移:

python manage.py makemigrations 
python manage.py migrate 

从对新用户这一点将会通过这个新的模型来表示(你必须处理迁移手动),包括您可能使用的任何地方self.request.user

+0

感谢您的回答。什么是对不断变化的以下allauth设置写我AbstractUser和管理类的优势: 'ACCOUNT_USER_MODEL_USERNAME_FIELD =无 ACCOUNT_EMAIL_REQUIRED =真 ACCOUNT_USERNAME_REQUIRED =假 ACCOUNT_AUTHENTICATION_METHOD =“邮件”' – RobChooses

+0

其实,我完全糊涂了。使用这些allauth设置,ACCOUNT_USER_MODEL_USERNAME_FIELD = None等,在Django管理员的“添加用户”下,它表示仍然需要用户名。 – RobChooses

+0

我认为使用自定义AbstractUser是最有意义的,因为您不必为了跟踪用户配置文件信息而调用关系,因为'auth.model.User'和任何其他'Model'。尽管我不能说'阿拉思特'。 – IAmKale