Django的Auth模块

Auth模块

我们在创建好一个Django项目后执行数据库迁移命令会自动生成很多表

其中有auth_user等表

Django在启动之后就可以直接访问admin路由,需要输入用户名和密码,数据参考的就是auth_user表,并且必须是管理员才能进入

依赖于auth_user表完成用户相关的所有功能

创建超级用户(管理员)

python manage.py createsuperuser

比对密码和用户名是否正确

括号内必须同时传入用户名和密码

复制代码
user_obj = auth.authenticate(request, username=username, password=password)

保存用户状态

复制代码
auth.login(request, user_obj)  # 类似于request.session[key]=user_obj
# 只要执行了该方法,你就可以在任何地方通过request.user获取到当前登录的对象

判断用户当前是否登录

复制代码
request.user.is_authenticated()

获取当前登录用户

复制代码
request.user

校验用户是否登录装饰器

复制代码
from django.contrib.auth.decorators import login_required
复制代码
@login_required(login_url='/login/')  # 局部配置:用户没有登录跳转到login_url后面指定的网址
复制代码
#全局配置
LOGIN_URL='/login/'

比对密码

复制代码
request.user.check_password(old_password)  # 返回bool

修改密码

复制代码
# 设置新密码
request.user.set_password(new_password)  # 仅仅修改对象的属性
# 操作数据库
request.user.save()

注销

复制代码
auth.logout(request)

注册

复制代码
User.objects.create_user(username=username,password=password
复制代码
from django.contrib.auth.models import User

urls.py

python 复制代码
from django.contrib import admin
from django.urls import path
from app01 import views
urlpatterns = [
    path('admin/', admin.site.urls),
    #登录功能
    path('login/', views.login),
    #判断用户是否登录
    path('home/', views.home),
    #修改密码
    path('set_password/',views.set_password),
    #注销功能
    path('logout/',views.logout),
    #注册功能
    path('reg/',views.reg)
]

views.py

python 复制代码
from django.shortcuts import render, redirect, HttpResponse
from django.contrib import auth

# 使用auth模块要用就用全套
def login(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        # 去用户表中校验数据
        # 1.表如何获取
        # 2.密码如何比对
        user_obj = auth.authenticate(request, username=username, password=password)
        if user_obj:
            # 保存用户状态
            auth.login(request, user_obj)  # 类似于request.session[key]=user_obj
            # 只要执行了该方法,你就可以在任何地方通过request.user获取到当前登录的对象
            return redirect('/home/')
        '''
        1.自动查找auth_user标签
        2.自动给密码加密再比对
        该方法注意事项
            括号内必须同时传入用户名和密码
            不能只传用户名
        '''
    return render(request, 'login.html')


from django.contrib.auth.decorators import login_required

'''
1.如果全局也配置了,优先级 局部>全局
2.全局配置不需重复写代码,但是跳转单一。局部配置好处在于不同的视图函数在用户没有登录的情况下可以跳到不同页面
'''

@login_required(login_url='/login/')  # 局部配置:用户没有登录跳转到login_url后面指定的网址
def home(request):
    print(request.user)  # 用户对象    如果django_session表中没有数据就拿到AnonymousUser匿名用户
    # print(request.user.is_authenticated()) #匿名用户返回False,用来判断当前用户是否登录
    # 自动去django_session表中查看用户对象给你封装到request.user中
    return HttpResponse('ok')

@login_required(login_url='/login/')
def set_password(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        old_password = request.POST.get('old_password')
        new_password = request.POST.get('new_password')
        # 对比新旧密码是否一致
        if old_password == new_password:
            # 校验老密码
            is_right = request.user.check_password(old_password)  # 返回bool
            if is_right:
                # 设置新密码
                request.user.set_password(new_password)  # 仅仅修改对象的属性
                # 操作数据库
                request.user.save()
    return render(request, 'set_password.html', locals())
@login_required
def logout(request):
    auth.logout(request)
    return redirect('/login/')
from django.contrib.auth.models import User
def reg(request):
    if request.method=='POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        #操作auth_user表写入数据
        #User.objects.create() 不能用create,密码没有加密处理
        #创建普通用户
        User.objects.create_user(username=username,password=password)
    return render(request,'reg.html')

auth模块表扩展

models.py

python 复制代码
from django.db import models
from django.contrib.auth.models import User,AbstractUser
# Create your models here.
class UserInfo(AbstractUser):
    '''
    如果继承了AbstractUser
    那么在执行数据库迁移命令的时候auth_user就不会被创建出来了
    而UserInfo表中会出现auth_user所有的字段 外加自己扩展的字段
    这样你能直接点击你自己的表更加快速的完成操作和扩展
    前提:
        1.在继承之前没有执行过数据库迁移命令
            auth_user没有被创建,如果当前库已经创建了那么就重新换个库
        2.继承的类里面不要覆盖AbstractUser里面的字段名
            表里面所有的字段都不要动,只要扩展字段即可
        3.需要在配置文件中告诉Django你要用UserInfo代替auth_user
            AUTH_USER_MODEL='app01.UserInfo'
                             应用名.表名
    '''
    phone=models.BigIntegerField()
#替换了auth_user表,auth模块还是正常使用,参考的表页从原来的auth_user变成了UserInfo
相关推荐
计算机编程-吉哥几秒前
计算机毕业设计 基于Python的社交音乐分享平台的设计与实现 Python+Django+Vue 前后端分离 附源码 讲解 文档
python·django·毕业设计·课程设计·毕业论文·计算机毕业设计选题·音乐分享平台
程序员大金7 分钟前
基于SpringBoot+Vue+MySQL的在线学习交流平台
java·vue.js·spring boot·后端·学习·mysql·intellij-idea
shinelord明8 分钟前
【Python】Python知识总结浅析
开发语言·人工智能·python
qq_25183645714 分钟前
基于SpringBoot vue 医院病房信息管理系统设计与实现
vue.js·spring boot·后端
雷神乐乐39 分钟前
Python常用函数
开发语言·python
qq_2518364571 小时前
基于springboot vue3 在线考试系统设计与实现 源码数据库 文档
数据库·spring boot·后端
向上的车轮1 小时前
Django学习笔记四:urls配置详解
笔记·学习·django
2401_858120531 小时前
古典舞在线交流平台:SpringBoot设计与实现详解
java·spring boot·后端
赐你岁月如歌1 小时前
如何使用ssm实现基于web的网站的设计与实现+vue
java·后端·ssm
闲宇非鱼2 小时前
微服务到底是技术问题还是管理问题?
java·后端·微服务