首页 > 其他分享 >Django中间件三个了解方法,基于Django中间件的功能设计,Django操作cookie与session

Django中间件三个了解方法,基于Django中间件的功能设计,Django操作cookie与session

时间:2022-12-26 22:33:18浏览次数:45  
标签:return 中间件 request Django session cookie

目录

Django中间件三个了解方法,基于Django中间件的功能设计,Django操作cookie与session

今日内容概要

  • Django中间件三个了解的方法
  • 基于Django中间件的功能设计
  • cookie与session简介
  • Django操作cookie
  • Django操作session

今日内容详细

Django中间件三个了解的方法

1.process_view
	路由匹配成功之后执行视图函数/类之前自动触发(顺序同process_request)
2.process_exception
	视图函数/类执行报错自动触发(顺序同process_response)
3.process_template_response
	视图函数/类返回的HttpResponse对象含有render并且对应一个方法的时候自动触发(顺序同procss_response)

基于Django中间件的功能设计

将各个功能制作成配置文件的字符串形式
	如果想拥有该功能就编写对应的字符串
	如果不想有该功能则注释掉对应的字符串
 
补充知识	
	如果利用字符串导入模块
import importlib
s1 = 'bbb.b'  # aaa.bbb.ccc.b
res = importlib.import_module(s1)  # from aaa.bbb.ccc import b
print(res)  # <module 'bbb.b' from 'D:\\pythonProject03\\djangomiddle\\bbb\\b.py'>
'''注意字符串的结尾最小单位只能是py文件 不能是py文件里面的变量名'''
思考django中间件是如何处理的(最小单位是类名)


需求分析
	模拟编写一个消息通知功能(微信、qq、邮箱)
 
方式1:基于函数封装的版本
	没有眼前一亮的感觉 很一般
方式2:基于django中间件的功能设计
 	眼前一亮 回味无穷

cookie与session简介

"""
回忆:HTTP协议四大特性
	1.基于请求响应	
	2.基于TCP、IP作用于应用层之上的协议
	3.无状态
		不保存客户端的状态
	4.无连接
"""
最开始的网站都不需要用户注册 所有人来访问获取到的数据都是一样的
随着互联网的发展很多网站需要指定当前用户的状态

cookie
	保存在客户端与用户状态相关的信息
session
	保存在服务端与用户状态相关的信息
ps:session的工作需要依赖于cookie
    
补充:浏览器有资格拒绝保存服务端发送过来的cookie数据

django操作cookie

from django.shortcuts import render,HttpResponse,redirect
return render()
return HttpResponse()
return redirect()

要想操作cookie就不能直接返回HttpResponse对象 必须先用变量接收
obj1 = render()
return obj1
obj2 = HttpResponse()
return obj2
obj3 = redirect()
return obj3
'''后端代码简单练习
def login_func(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        if username == 'jason' and password == '123':
            # 校验成功之后跳转页面home并给对象一个cookie字符串
            obj = redirect('/home/')
            obj.set_cookie('name', username)
            return obj
    return render(request, 'loginPage.html')


def home_func(request):
    # 先获取用户的cookie数据
    if request.COOKIES.get('name'):
        return HttpResponse('home页面 只有登录的用户才可以查看')
    else:
        return redirect('/login/')'''
def login_author(func_name):
    def inner(request, *args, **kwargs):
        # print(request.path)  # 获取用户输入的路由信息
        # print(request.path_info)  # 获取用户输入的路由信息
        target_path = request.path_info
        # print(request.get_full_path())  # 获取用户输入的路由信息+问号后面携带的数据
        # 先获取用户的cookie数据
        if request.COOKIES.get('name'):
            res = func_name(request, *args, **kwargs)
            return res
        else:
            return redirect('/login/?next=%s' % target_path)
    return inner


def login_func(request):
    if request.method == 'POST':
        username = request.POST.get('username')
        password = request.POST.get('password')
        if username == 'jason' and password == '123':
            target_path = request.GET.get('next')
            if target_path:
                obj = redirect(target_path)
            else:
                # 校验成功之后跳转页面home并给对象一个cookie字符串
                obj = redirect('/home/')
            obj.set_cookie('name', username)
            return obj
    return render(request, 'loginPage.html')


@login_author
def home_func(request):
    # 先获取用户的cookie数据
    # if request.COOKIES.get('name'):
        return HttpResponse('home页面 只有登录的用户才可以查看')
    # else:
    #     return redirect('/login/')


@login_author
def home1_func(request):
    # 先获取用户的cookie数据
    # if request.COOKIES.get('name'):
        return HttpResponse('home1页面 只有登录的用户才可以查看')
    # else:
    #     return redirect('/login/')

django操作session

由于session是保存在服务器上面的数据 就应该有个地方能够存储
我们只需要执行数据库迁移命令即可 Django会自动创建很多需要的表

Django默认的session失效时间是14天

设置session	
	request.session['key'] = value
        1.生成一个随机字符串
        2.对value数据做加密处理 并在django_session表中存储
            随机字符串>>>加密数据
        3.将随机字符串也发送一份给客户端保存(cookie)
            sessionid:随机字符串
获取session	
	request.session.get('key')
        1.自动获取随机字符串
        2.去django_session表中根据随机字符串获取加密的数据
        3.自动解密数据并处理到request.sesion.get()中
    
补充说明
	1.可以设置过期时间		
 	2.存储session数据的位置也可以修改

标签:return,中间件,request,Django,session,cookie
From: https://www.cnblogs.com/zpf1107/p/17007069.html

相关文章

  • Cookie 携带 Secure 属性导致浏览器不能在请求中携带 SessionID 的问题。
    有Secure属性的Cookie意味着如果浏览器不是使用HTTPS与服务建立链接,那么这个cookie里的值不会随请求一起向服务器发送。要解决这个问题就需要在Nginx中把cookie......
  • django Cookie与Session
    djangoCookie与SessionCookie与Session简介回忆:HTTP协议四大特征1.基于请求响应2.基于TCP的应用层协议3.无状态:不保存客户端状态4.无连接最开始的网站都不需要用户......
  • django中间件
    django中间件内容概要django中间件简介django中间件两个重要方法django自定义中间件django中间件三个了解方法基于django中间件实现功能的插拔式设计内容详细djang......
  • Python爬虫学习:Cookie 和 Session 的区别是什么?
    一、含义Cookie意为“甜饼”,是由W3C组织提出,最早由Netscape社区发展的一种机制。目前Cookie已经成为标准,所有的主流浏览器如IE、Netscape、Firefox、Opera等都支持Cookie......
  • cookies与session
    前期cookies最开始的浏览器,每次向服务器的请求都自报家门,即每发一次请求,都把用户名和密码都发过去:当用户第一次把用户名和密码输对了之后。浏览器自动保存用户名和密码。......
  • 基于DJango和Pybind11,实现网络后端调用OpenCV算法
    本Blog来源于实际项目,所采用框架组合中,OpenCV实现算法主体、pybind11完成OpenCV的Python封装、django提供Web应用服务,三者协同配合,共同实现“网络后端调用OpenCV算法,解决特......
  • Django:auth认证模块
    目录一、django的auth认证模块1.什么是auth模块2.生成auth物理表二、创建django-admin账户1.创建超级管理员2.注册超级管理员账户3.登录admin账户三、auth模块中的方法1.导......
  • django中间件
    django中间件django默认有七个中间件并且还支持用户自定义中间件中间件主要可以用于:网站访问频率的校验用户权限的校验等全局类型的功能需求MIDDLEWARE=['......
  • Django之forms组件内容,Django中间件
    目录Django之forms组件内容,Django中间件今日内容概要今日内容详细forms组件渲染标签forms组件展示信息forms组件校验补充forms组件参数补充forms组件源码剖析modelform组件......
  • django forms组件,model from组件
    djangoforms组件,modelfrom组件内容概要forms组件简单使用form组件渲染标签forms组件校验补充forms组件参数补充forms组件源码剖析modelfrom组件forms组件小需求......