Django中间件(Middleware)处理请求
关注公众号“轻松学编程”了解更多。
1、面向切面编程
- 切点(钩子)
- 切点允许我们动态的在原有逻辑中插入一部分代码
- 在不修改原有代码的情况下,动态注入一部分代码
- 默认情况,不中断传播,切点会自动愈合(自动执行原有逻辑)
- 如果我们执行了中断操作(return,raise),没接上,会直接到程序结尾
- 五个切面:1、请求交给路由处理之前;2、请求交给视图处理之前;3、请求交给视图渲染后;4、渲染结果返回给模板之前;5、出现异常。
2、Django中的中间件
框架内置切点
- init
- 没有参数,服务器响应第一个请求的时候自动调用,用户确定是否启用该中间件
- process_request(self,request)
- 在执行视图前被调用,每个请求上都会调用
- 不返回或返回HttpResponse对象
- process_view(self,request,view_func,view_args,view_kwargs)
- 调用视图之前执行,每个请求都会调用
- 不返回或返回HttpResponse对象
- process_template_response(self,request,response)
- 在视图刚好执行完后进行调用,每个请求都会调用
- 不返回或返回HttpResponse对象
- process_response(self,request,response)
- 所有响应返回浏览器之前调用,每个请求都会调用
- 不返回或返回HttpResponse对象
- process_exception(self,request,exception)
- 当视图抛出异常时调用
- 不返回或返回HttpResponse对象
from django.http import HttpResponse
from django.shortcuts import render, redirect
from django.urls import reverse
from django.utils.deprecation import MiddlewareMixin from MidUpVcode.settings import BLACK_LIST, VIP_LIST
'''
所有的钩子函数都可以返回一个Response
一旦钩子函数返回了Response,整个请求的受理就结束了
'''
# 继承于框架中间件
class MyappMiddleware(MiddlewareMixin):
# 中间件的初始化方法,全局执行一次
# def __init__(self, get_response=None):
# super(MyappMiddleware, self).__init__()
# print(">>>>>>>>>> MyappMiddlware __init__") # 下钩子于所有路由被交给路由表之前
def process_request(self, request):
# 获取客户端IP地址
clientIp = request.META['REMOTE_ADDR']
# 请求的路由
url = request.path
print(">>> process_request", request, clientIp, url) # # 屏蔽黑名单用户
# 只要客户端IP在黑名单中
# if clientIp in BLACK_LIST:
# 直接渲染fuckoff.html并立刻返回
# return render(request,'fuckoff.html') # # 当VIP用户访问福利页面时提供更多好的服务
# if clientIp in VIP_LIST and url=='/myapp/fuli/':
# return render(request, 'fuli.html', context={'imgpath': 'meinv1.jpg'}) # 福利页必须登录了才能查看
if url == '/myapp/fuli/' and not request.session.get('uname', None):
return redirect(reverse('myapp:login')) # 下钩子于所有路由请求被交给视图函数之前
def process_view(self, request, view_func, view_args, view_kwargs):
print(">>> process_view", request, view_func, view_args, view_kwargs) # 理论上下钩子于所有路由请求的模板被渲染完成以后
# 这个函数实测无法回调
def process_template_response(self, request, response):
print(">>>>>>>>>> process_template_response", request, response)
return response # 下钩子于所有路由的响应被返回之前
def process_response(self, request, response):
print(">>>>>>>>>> process_response", request, response)
return response def process_exception(self, request, exception):
print(">>>>>>>>>> process_exception", request, exception)
return redirect('/')- init
3、自定义中间件
用途
- 统计
- 黑名单
- 白名单
- 反爬(redis)
- 界面友好化(捕获异常)
流程
在工程目录下创建middleware目录
继承MiddleWareMixin
class LearnAOP(MiddlewareMixin):
def process_request(self,request):
print('request的路径',request.GET.path)
覆写切点方法,实现自己的功能
- 如果我们逻辑中没有返回值,那么程序执行的时候会按照原有逻辑执行
- 如果我们做出了返回,那么程序将会从切点处切开,直接回到浏览器
在settings中进行注册
MIDDLEWARE = [
...
# 注册自定义的中间件
'middleware.MyMiddleware.MyappMiddleware',
...
]
后记
【后记】为了让大家能够轻松学编程,我创建了一个公众号【轻松学编程】,里面有让你快速学会编程的文章,当然也有一些干货提高你的编程水平,也有一些编程项目适合做一些课程设计等课题。
也可加我微信【1257309054】,拉你进群,大家一起交流学习。
如果文章对您有帮助,请我喝杯咖啡吧!
公众号
关注我,我们一起成长~~
Django中间件(Middleware)处理请求的更多相关文章
- django中间件Middleware
熟悉web开发的同学对hook钩子肯定不陌生,通过钩子可以方便的实现一些触发和回调,并且做一些过滤和拦截. django中的中间件(middleware)就是类似钩子的一种存在.下面我们来介绍一下,并 ...
- 使用django 中间件在所有请求前执行功能
django中间是一个轻级,低耦合的插件,用来改变全局的输入和输出. 一 如何使用中间件 定义中间件 注册中间件 # 这是一个中间件代码片段的说明,在各个位置的代码将在何时执行 def simple_ ...
- Django中间件-跨站请求伪造-django请求生命周期-Auth模块-seettings实现可插拔配置(设计思想)
Django中间件 一.什么是中间件 django中间件就是类似于django的保安;请求来的时候需要先经过中间件,才能到达django后端(url,views,models,templates), ...
- django 中间件记录所有请求及请求执行时间
class LoggingMiddleware(object): def process_request(self, request): request.start_time = time.time( ...
- 利用Django中间件middleware解决用户未登录问题(转)
add by zhj: Django的中间件一般用于处理通用性的问题,分为五种,按处理顺序为request_middleware,view_middleware,exception_middlewar ...
- Django中间件 (middleware)
中间件是处理django的请求和响应的框架级别的钩子,本质是一个类(直白一点中间件是帮助我们在视图函数执行之前和执行之后都可以做一些额外的操作) 由于其影响的是全局,所以需要谨慎使用,使用不当会影响性 ...
- Django中间件如何处理请求
Django中间件 在http请求 到达视图函数之前 和视图函数return之后,django会根据自己的规则在合适的时机执行中间件中相应的方法. Django1.9版本以后中间件的执行流程 1. ...
- Django中间件的5种自定义方法
阅读目录(Content) Django中间件 自定义中间件 中间件(类)中5种方法 中间件应用场景 回到顶部(go to top) Django中间件 在http请求 到达视图函数之前 和视图函 ...
- Python菜鸟之路:Django 中间件
前言 在正式说Django中间件之前需要先了解Django一个完整的request的处理流程.我从其他网站扒了几张图过来. 图片一: 文字流程说明:如图所示,一个 HTTP 请求,首先被转化成一个 H ...
随机推荐
- Android捕捉错误try catch 的简单使用
基本语法 try{ //可能发生错误的程式码 }catch(具体错误 e){ //具体错误有就写,没有就不写,有多个,就写多个catch e.printStackTrace(); //在命令行打印错误 ...
- C++ 构造函数 隐式转换 深度探索,由‘类对象的赋值操作是否有可能调用到构造函数’该实验现象引发
Test1 /** Ques: 类对象的赋值操作是否有可能调用到构造函数 ? **/ class mystring { char str[100]; public: mystring() //myst ...
- Shiro入门学习---使用自定义Realm完成认证|练气中期
写在前面 在上一篇文章<shiro认证流程源码分析--练气初期>当中,我们简单分析了一下shiro的认证流程.不难发现,如果我们需要使用其他数据源的信息完成认证操作,我们需要自定义Real ...
- Java 文件 IO 操作
window 路径分割符: \ 表示 windows 系统文件目录分割符 java 代码在 windows 下写某个文件的话需要下面的方式 D:\\soft\\sdclass.txt 其中一个单斜杠 ...
- c++缓冲区std::wstringbuf
参考:http://www.cplusplus.com/reference/sstream/wstringbuf/ class <sstream> std::wstringbuf type ...
- 《C++primerplus》第4章练习题
注:略过部分题目,修改了题设要求,实现差不多的功能 1.使用字符数组.要求用户输入姓名,等第和年龄,输出其姓名和年龄,等第降一级(即字母高一级). #include<iostream> u ...
- 11 . Nginx核心原理讲解
应用场景优缺点 应用场景 // 1.静态请求 // 2.反向代理 // 3.负载均衡 // 4.资源缓存 // 5.安全防护 // 6.访问限制IP // 7.访问认证 /* 核心主要是以下三个应用: ...
- EDI模拟实验
EDI模拟实验 [实验目的] ⑴.了解EDI报文的格式和特点. ⑵.掌握EDI报文生成和发送流程. [实验条件] ⑴.个人计算机一台,预装Windows XP操作系统和浏览器 ⑵.计算机通过局域网形式 ...
- 题解:[COCI2011-2012#5] BLOKOVI
题解:[COCI2011-2012#5] BLOKOVI Description PDF : https://hsin.hr/coci/archive/2011_2012/contest5_tasks ...
- day26 Pyhton 面向对象复习
一 class 类名(): pass 对象 object 对象 = 类名() class Person: pass print(Person)#<class '__main__.Person'& ...