python middleware_Django框架中间件(Middleware)用法实例分析

本文实例讲述了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('/')

3、自定义中间件

用途

统计

黑名单

白名单

反爬(redis)

界面友好化(捕获异常)

流程

在工程目录下创建middleware目录

继承MiddleWareMixin

class LearnAOP(MiddlewareMixin):

def process_request(self,request):

print('request的路径',request.GET.path)

覆写切点方法,实现自己的功能

如果我们逻辑中没有返回值,那么程序执行的时候会按照原有逻辑执行

如果我们做出了返回,那么程序将会从切点处切开,直接回到浏览器

在settings中进行注册

MIDDLEWARE = [

...

# 注册自定义的中间件

'middleware.MyMiddleware.MyappMiddleware',

...

]

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值