python中间件的作用_Django2.1.3 中间件使用详解

环境

Win10

Python3.6.6

Django2.1.3

中间件作用 中间件用于全局修改Django的输入或输出。

中间件常见用途

缓存

会话认证

日志记录

异常

中间件执行流程

全局异常捕捉实现

创建django项目&添加app

django-admin startproject middleware

cd middleware

django-admin startapp app

添加app到项目

# middleware/settings.py

# INSTALLED_APPS最后添加 app

INSTALLED_APPS = [

'app',

]

编辑中间件并添加到项目

注:中间件注册访问有一定的关联性,位置不可以随意放

# 创建app/middleware.py并编辑

from django.http import JsonResponse

class CustomMiddleware:

def __init__(self, get_response):

print("程序启动时执行, 只执行一次")

self.get_response = get_response

def __call__(self, request):

print("中间件开始")

response = self.get_response(request)

print("中间件结束")

return response

def process_view(self, request, view_func, view_args, view_kwargs):

print("请求实际函数前执行")

def process_exception(self, request, exception):

print("程序异常时执行")

return JsonResponse({"msg": exception.args[0], "code": -1})

编辑middleware.setttings.py

MIDDLEWARE = [

...

'app.middleware.CustomMiddleware'

]

编写一个异常

# app/views.py

from django.http import JsonResponse

def json_response(request):

print('json_response')

err = 3 / 0

return JsonResponse({"msg": "ok", "code": 0})

添加到路由

# middleware/urls.py

from app.views import json_response, view_response

urlpatterns = [

...

path("view", view_response)

]

运行测试

访问: http://127.0.0.1:8000/json/

结果

另一个觉用途日志记录

# 在中间件函数process_view中添加

print("path: {}; method: {}; data: {}".format(request.get_full_path(), request.method, request.body or ''))

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值