【Django】教程-9-登录+退出

【Django】教程-1-安装+创建项目+目录结构介绍
【Django】教程-2-前端-目录结构介绍
【Django】教程-3-数据库相关介绍
【Django】教程-4-一个增删改查的Demo
【Django】教程-5-ModelForm增删改查+规则校验【正则+钩子函数】
【Django】教程-6-搜索框-条件查询前后端
【Django】教程-7-分页,默认使用django的
【Django】教程-8-页面时间组件

15. 用户认证,可以多种方式后面会介绍

15.1

浏览器登录服务器,服务器给浏览器凭证,服务器自己存一个凭证;下次带着凭证过来,服务器验证凭证,验证通过,可继续操作
登录成功views中login添加,下面这行代码

相当于:① 会给浏览器生成一个cookie的随机字符串;

② 服务器数据库记录这个随机字符串在django_session表中;

③ 服务器记录info=小明,session, 当然你可以使用任意属性,不一定是key,可以自定义属性名字随便起。

request.session("info")="小明"

例如:

python 复制代码
def login(req):
    """用户登录"""
    """ modelform 方式添加用户"""
    if req.method == 'GET':
        user = LoginForm()
        return render(req, 'login/login.html', {"user": user})
    # 用户post提交,数据校验
    user = LoginForm(data=req.POST)
    if user.is_valid():
        # 生成cookie和session
        req.session["key"] = {"username": req.POST.get("username")}
        
        return redirect("/admin/list")
    # # 校验失败, 在页面上展示错误信息
    return render(req, 'login/login.html', {"user": user})

对每个页面添加,判断,如果没有登录属性,就跳转到登陆页面

python 复制代码
def admin_list(request):
    # 每一个views中,都需要添加,认证信息,如果没有,就跳转到登录
    request.session.get("key")
    if not info:
        return redirect("/login/")

15.2 中间件方式

  • 定义中间件
python 复制代码
from django.utils.deprecation import MiddlewareMixin
from django.shortcuts import redirect

class AuthMiddleware(MiddlewareMixin):

    def process_request(self, request):
        print("M1 进来了!")
        # 如果没有返回值,返回None,继续往下走
        # 如果有返回值,HttpResponese 返回了,不往下走了

        # 如果是登录请求,请求继续
        if request.path_info == '/login/':
            return

        # 1. 读取当前访问的用户session信息,说明已经登录过,可以继续往下走
        info_dict = request.session.get("info")
        print(info_dict)
        if info_dict:
            # 继续往下走
            return

        # 如果没有登录信息,去登录页面
        return redirect('/login/')

    def process_response(self, response):
        print("M1 走了!")
        return response
  • 应用中间件, settings.py
python 复制代码
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
    # 'appTang.middleware.LoginMiddleware.LoginRequiredMiddleware',
    'appTang.middleware.auth.AuthMiddleware'
]
  • 登录views account.py
python 复制代码
from django.shortcuts import render, redirect
from appTang.forms import LoginForm


def login(req):
    """用户登录"""
    """ modelform 方式添加用户"""
    if req.method == 'GET':
        user = LoginForm()
        return render(req, 'login/login.html', {"user": user})
    # 用户post提交,数据校验
    user = LoginForm(data=req.POST)
    if user.is_valid():
        # 需要添加用户认证成功信息
        req.session["info"] = {"username": req.POST.get("username")}
        print("登录成功")
        return redirect("/admin/list")


    # # 校验失败, 在页面上展示错误信息
    return render(req, 'login/login.html', {"user": user})
  • 退出
python 复制代码
def logout(req):
    """注销"""
    req.session.clear();
    return redirect("/admin/list")
相关推荐
DXDZ20225 小时前
12V大功率ESD产品TVS20H12T5G 5000W 200A VC24V助力快充接口浪涌防护
5g·django·symfony
YJlio8 小时前
Registry Usage (RU) 学习笔记(15.5):注册表内存占用体检与 Hive 体量分析
服务器·windows·笔记·python·学习·tcp/ip·django
Psycho_MrZhang9 小时前
Django/Flask/FastAPI简要对比分析
django·flask·fastapi
xj7573065339 小时前
精通django 第二章 视图和URL
数据库·django·sqlite
YJlio1 天前
RAMMap 学习笔记(15.2):Processes / Priority / Summary——从“谁在用”和“谁更重要”看物理内存
开发语言·笔记·python·学习·django·pdf·硬件架构
xj7573065331 天前
《精通Django》第一章 入门
数据库·django·sqlite
哈里谢顿2 天前
验证 list() 会调用 `__len__` 方法的深度解析
python·django
luoluoal2 天前
基于python的语音和背景音乐分离算法及系统(源码+文档)
python·mysql·django·毕业设计·源码
luoluoal2 天前
基于python的英汉电子词典软件(源码+文档)
python·mysql·django·毕业设计·源码
luoluoal2 天前
基于python的旅游景点方面级别情感分析语料库与模型(源码+文档)
python·mysql·django·毕业设计·源码