一、什么是Auth模块

  Auth模块是Django自带的用户认证模块,默认使用 auth_user 表来存储用户数据。

二、使用方法

1.创建超级用户

  python3 manage.py createsuperuser

  输入用户名,邮箱(可以不输入),密码,确认密码(成功创建超级用户,并在auth_user表中插入一条数据,因为密码必须加密所有不能手动插入)

2.验证用户

from django.contrib import auth
# 相当于在查询:user=models.User.objects.filter(name=name,pwd=pwd).first()
user = auth.authenticate(request, username=name, password=pwd) # 如果校验通过,会返回一个user对象,通过判断user对象,校验是否验证

3.登录

auth.login(request,user)
# 其实就是在session中写了一条数据

  一旦登录成功,调了这个函数login(request,user),以后再视图类,函数中的request对象中,就有一个user对象,就是当前登录的用户对象;如果没有登录,request.user=AnonymousUser是匿名用户。

4.注销

auth.logout(request)
# 内部:调用了request.session.flush(),删除了登录状态

5.登录认证装饰器

from django.contrib.auth.decorators import login_required
@login_required(redirect_field_name='awsl',login_url='/login/') # 可以局部配置# # redirect_field_name:修改?后面的key值,
# login_url:如果没有登录,跳转到的页面 # 可以全局配置(在setting中)
# 全局的配置,如果没有登录,跳到这个路由
LOGIN_URL='/login/'

7.创建用户

from django.contrib.auth.models import User
# 创建超级用户和普通用户
# 不能用create,创建的密码没加密
# user=User.objects.create(username=name,password=pwd)
# 创建超级用户
user=User.objects.create_superuser(username=name,password=pwd)
# 创建普通用户
user=User.objects.create_user(username=name,password=pwd)

8.校验密码

# 先拿到用户(可以是登录用户,可以现查)
request.user.check_password(pwd)

9.修改密码

user.set_password(pwd)
user.save() # 一定要调用save(),否则是不保存的

10.检验验证

  is_authenticated(),如果通过验证,是true反之false

11.其他方法

  is_active:禁止登录网站(用户还存在,封号)
  is_staff:是否对网站有管理权限(能不能登录admin)

12.删除用户

  orm删除

三、扩展默认的auth_user表

方法一:一对一和auth_user表做关联

from django.contrib.auth.models import User
class UserDetail(models.Model):
phone=models.CharField(max_length=32)
# 一对一跟auth_user表做关联
# 如果是从外部引入的表模型,是不能加引号的
# 如果加引号,只是在当前model找
user=models.OneToOneField(to=User)

方法二:继承AbstractUser

from django.contrib.auth.models import AbstractUser
class UserInfo(AbstractUser):
# username,password之前auth_user表里的字段都有
phone=models.CharField(max_length=32)
sex=models.BooleanField()
# 在setting中配置,做数据库迁移,以后就没有auth_user这张表,认证组件用的就是UserInfo表
AUTH_USER_MODEL ='app01.UserInfo'

最新文章

  1. 通俗易懂------this指向
  2. QT基本使用
  3. Tesseract 对验证码的识别原理和实现步骤
  4. Lucene全文检索框架
  5. Python属性、方法和类管理系列之----描述符类
  6. vc获取时间戳
  7. _cdel stdcall
  8. viewpager的滑动
  9. glusterfs 4.0.1 event模块 分析笔记1
  10. Redis与Memocache的区别
  11. Mysql表的约束设计和关联关系设计
  12. nginx——配置 Nginx 错误页面优雅显示
  13. WIN7以上系统安装VB6的解决办法,附上个批处理。
  14. C# if---else---练习题整理
  15. hbase记录-修改压缩格式
  16. super()、this属性与static静态方法的执行逻辑
  17. WEB网页监控系统的设计框架思路具体解释
  18. SHU 414 - 字符串进制转换
  19. 通过WebRTC实现实时视频通信(二)
  20. pat 打印沙漏

热门文章

  1. RESTful API Design: 13 Best Practices to Make Your Users Happy
  2. C# .net core 相对路径转绝对路径 (官方示例)
  3. vue-cli使用笔记
  4. tensorflow学习(一)
  5. PHP Closure(闭包)类详解
  6. Windows下多个JDK版本的切换方法
  7. 范仁义html+css课程---6、表格
  8. Tomcat的并发能力
  9. pip常用命令(转载)
  10. 【转】使用AllureReport生成测试报告