User对象是认证系统的核心。
一旦一个模型里面的Meta里面abstract = True,那这个模型就是抽象模型。抽象模型有啥用呢?就是用来被继承。我们在迁移的时候,他不会把这个模型也去映射表。可以理解为就是一个模板,其他模型把他继承之后,就能共用里面的字段(比如AbstractUser里面的username、first_name、last_name、email等等)。
其中 USERNAME_FIELD 就是指定到底是哪个字段作为django默认的凭证。REQUIRED_FIELDS指定的字段和你username是否一对一匹配的上。
user = User.objects.create_user(username, email, password, **extra_fields)
用户认证(用户登录)的方法
from django.contrib.auth import authenticate
user = authenticate(username=username, password=password, **kwargs)
设置密码:set_password(raw_password)
校验密码:check_password(raw_password)
思考:为什么要自定义用户模型类?
在通过 createsuperuser 管理命令创建用户时,将提示输入mobile字段
REQUIRED_FIELDS = ['mobile']
from django.db import models
from django.contrib.auth.models import AbstractUser
from django.core.exceptions import ValidationErrordef validate_mobile(value):if not re.match(r'1[3-9]\d{9}', value): raise ValidationError('手机号码格式不正确')class User(AbstractUser): """Custom user model.Add mobile field to Django user model """# 添加一个mobile字段mobile = models.CharField('手机号码', max_length=11, unique=True, help_text='手机号码', null=True, blank=True,error_messages={'unique': '手机号码已注册'}, validators=[validate_mobile])# 如果希望用email作为用户名,# USERNAME_FIELD = 'email'def __str__(self): return self.usernameclass Meta:db_table = 'tb_user' # 表 名verbose_name = 'user' # 站点显示名verbose_name_plural = 'users' # 复数显示REQUIRED_FIELDS = ['mobile'] # 在通过 createsuperuser 管理命令创建用户时,将提示输入mobile字段
模型写好之后,是不是要迁移?但是现在不能去迁移?为啥?因为现在去迁移会跟我们本身自带的User模型造成冲突。所以我们要去认证只能有一个用户模型。往下看第四大点。
1. Django自带用户认证系统,核心就是User对象,并封装了一系列可用的方法和属性。
2. Django用户认证系统包含了一系列对用户的操作,比如:模型类,认证,权限,分组,密码处理等。
3. Django用户认证系统中的用户模型类可以自定义,最简单的方法是继承自AbstractUser。
4. 更多Django中的自定义验证见官方文档
Django是通过配置项AUTH_USER_MODEL 来确定项目中到底使用哪个用户模型,所以我们需要修改配置指定我们的自定义的用户模型。
AUTH_USER_MODEL = '应用名.模型类名'
注意:应用要在INSTALLED_APPS 中注册,且一定要在第一次迁移之前要设置好此项
# 指定本项目用户模型类 settings.py 设置
AUTH_USER_MODEL = 'users.User'
python manage.py makemigrations
python manage.py migrate
1. 用户认证系统中的用户模型类,是通过全局配置项AUTH_USER_MODEL 决定的。
2. 如果迁移自定义用户模型类,必须先配置AUTH_USER_MODEL 。
3. 注意在迁移之前,运行服务会报错,因为默认项目依赖用户模型
在通过 createsuperuser 管理命令创建用户时,将提示输入mobile字段
REQUIRED_FIELDS = ['mobile']
进入shell之前,我们先安装ipython
pip install ipython
密码是加密的,这个就不说啦。就是给大家看一哈。
is_authenticated
上面我通过 python manage.py createsuperuser 创建超级管理员的时候,然后我在shell中查看daxia用户的密码发现是加密。
但是我通过 User.objects.create(username='test',password='123456')去创建用户的时候,发现密码却是明文。(TODO:后面去校验的时候永远不会通过)
此时我用User.objects.create_user(username='健健', password='123456')去创建用户的时候,发现密码确实加密的。
大家应该发现区别了吧~
验证通过的话会返回这个用户
from django.contrib.auth import authenticate
user = authenticate(username=username, password=password, **kwargs)
验证返回不通过的话,就不会返回
因为上面我们create创建的用户的密码是明文的,那这个时候我们把他修改一下。
密码是不是加密啦。
注意:对象.set_password(raw_password)后,记得 对象.save()保存一下。