django允许重写默认的user mode,提供了一个setting 值,来指向自定义的model,
AUTH_USER_MODEL = 'users.User'
#users是app名
#User是用户model
如果你开始一个新项目,设定一个自定义的user model是更值得推荐的,即使默认的user model已经满足需求,这个model和默认的user model是一致的,但是可以使你在有需要的时候去自定义它。
from django.contrib.auth.models import AbstractUser
class User(AbstractUser):
pass
不要忘记让AUTH_USER_MODEL指向它,记得在创建任何migrations 或者运行migrate
之前做这个事情。
另外,在app的admin.py里注册这个model
from django.contrib import admin
from django.contrib.auth.admin import UserAdmin
from .models import User
admin.site.register(User, UserAdmin)
把所有用户相关的信息放在一个模型中,避免到相关模型中进行复杂的查询。
如果使用默认的认证后端,你的model必须有一个唯一字段,用来标识,可以是一个username,或者email地址,或者其他唯一键。
构建一个兼容的自定义user model最简单的方法是从AbstractBaseUser
.AbstractBaseUser
继承,提供了user model 的核心实现。包括哈希散列密码和token化的密码重置。
一些细节上的实现:
class MyUser(AbstractBaseUser):
identifier = models.CharField(max_length=40, unique=True)
…
USERNAME_FIELD = 'identifier' #描述用户模型上用作唯一标识符的字段名称的字符串。这通常是某种用户名,但也可以是电子邮件地址或任何其他唯一标识符。
class MyUser(AbstractBaseUser):
…
date_of_birth = models.DateField()
height = models.FloatField()
…
REQUIRED_FIELDS = ['date_of_birth', 'height'] #通过createsuperuser管理命令创建用户时将提示的字段名称列表。系统将提示用户为每个字段提供值。
is_active
一个布尔属性,指示用户是否被视为“活动”。此属性作为AbstractBaseUser
默认属性提供True
。
set_password
(raw_password)
把给到的原始密码保存为密码哈希
您还应该为您的用户模型定义自定义管理器。如果您的用户模型只定义username
,email
,is_staff
,is_active
,is_superuser
, last_login
,和date_joined
字段,和Django默认的一样,你可以只安装Django的UserManager
; 但是,如果您的用户模型定义了不同的字段,则需要定义一个自定义管理器,拓展BaseUserManager
提供的另外两种方法:
class models.``CustomUserManager
create_user()的原型
应该接受用户名字段,加上所有必填字段作为参数。例如,如果您的用户模型用email作为用户名字段
,并且date_of_birth作为
必填字段,create_user
则应定义为:
def create_user(self, email, date_of_birth, password=None):
# create user here
…
手机扫一扫
移动阅读更方便
你可能感兴趣的文章