一、用户注册页面准备
1、创建 APP应用users
2、定义register方法
3、注册users app应用
4、注册register路由
二、Django默认用户认证系统
1、Django自带用户认证系统
- 它处理用户账号、组、权限以及基于cookie的用户会话。
2、Django认证系统位置
- django.contrib.auth包含认证框架的核心和默认的模型。
- django.contrib.contenttypes是Django内容类型系统,它允许权限与你创建的模型关联。
3、Django认证系统同时处理认证和授权
- 认证:验证一个用户是否它声称的那个人,可用于账号登录。
- 授权:授权决定一个通过了认证的用户被允许做什么。
4、Django认证系统包含的内容
- 用户:用户模型类、用户认证。
- 权限:标识一个用户是否可以做一个特定的任务,MIS系统常用到。
- 组:对多个具有相同权限的用户进行统一管理,MIS系统常用到。
- 密码:一个可配置的密码哈希系统,设置密码、密码校验。
三、Django默认用户模型类:AbstractUser
1、Django默认User 对象基本属性:
- 创建用户必选: username、password
- 创建用户可选:email、first_name、last_name、last_login、date_joined、is_active 、is_staff、is_superuse
- 判断用户是否通过认证:is_authenticated
四、自定义用户模型类
- 自定义用户模型类:AbstractUser属性 + 自定义的属性
1、定义自定义用户模型
# ./apps/users/models.py
from django.db import models
from django.contrib.auth.models import AbstractUser
# 重写用户模型类, 继承自 AbstractUser
class User(AbstractUser):
"""自定义用户模型类"""
# 在用户模型类中增加 mobile 字段
mobile = models.CharField(max_length=11, unique=True, verbose_name='手机号')
# 对当前表进行相关设置:
class Meta:
db_table = 'tb_users'
verbose_name = '用户'
verbose_name_plural = verbose_name
# 在 str 魔法方法中, 返回用户名称
def __str__(self):
return self.username
2、指定用户模型类
- Django 用户模型类是通过全局配置项 AUTH_USER_MODEL 决定的
- Django的全局变量保存在conf.global_settings.py
- Django的全局变量保存在conf.global_settings.py
- 因为我们重写了用户模型类, 所以我们需要重新指定默认的用户模型类:
在 dev.py 文件中添加如下代码:
./lgshop/dev.py
# 指定自定义的用户名 app.模型
AUTH_USER_MODEL = 'users.User'
3、数据库迁移
python manage.py makemigrations
python manage.py migrate