目录
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