1.什么是django自带的用户系统?
Django内置了Auth认证系统,整个Auth系统可以分为三大部分,用户信息,用户权限和用户组,在数据库中分别对应auth_user,auth_permission和auth_group
2.还系统有什么优势
默认实现了用户的注册,用户登录,用户认证,注销,修改密码等功能
3.如何使用自带的用户系统(写出重要的方法或者配置):
创建表时继承AbstractUser,其中默认已经生成了基本的字段,但是手机等特殊字段需要自己添加
用户模型类(AbstractUser 介绍)
AbstractUser 介绍:
-
User对象基本属性:
-
创建一个用户表必有:username、password
-
创建一个用户表可有:emial、phone、first_name等
-
-
创建用户
user_obj = User.object.create(username=username,password=password)
-
用户认证的方法
Django 自带用户认证系统
它处理用户账号、组、权限以及基于 cookie 的用户会话
- Django 认证系统同时处理认证和授权
- 认证:验证一个用户是否它声称的那个人,可用于账号登录.
- 授权:授权决定一个通过了认证的用户被允许做什么.
- Django 认证系统包含的内容
- 用户:用户模型类、用户认证.
- 权限:标识一个用户是否可以做一个特定的任务,MIS 系统常用到.
- 组:对多个具有相同权限的用户进行统一管理,MIS 系统常用到.
- 密码:一个可配置的密码哈希系统,设置密码、密码校验.
-
处理密码方法
设置密码:set_password(raw_password)
校验密码:check_password(raw_password)
-
model
# 导入
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
-
settings
# Django 用户模型类是通过全局配置项 AUTH_USER_MODEL 决定的又因为我们重写了用户模型类, 所以我们需要重新指定默认的用户模型类:
# 指定本项目用户模型类
AUTH_USER_MODEL = 'users.User'