首页 > 编程 > Python > 正文

Django2.1.3 中间件使用详解

2020-02-15 23:47:21
字体:
来源:转载
供稿:网友

环境

Win10 Python3.6.6 Django2.1.3

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

中间件常见用途

缓存 会话认证 日志记录 异常

中间件执行流程

全局异常捕捉实现

创建django项目&添加app

django-admin startproject middlewarecd middlewaredjango-admin startapp app

添加app到项目

# middleware/settings.py# INSTALLED_APPS最后添加 appINSTALLED_APPS = [ 'app',]

编辑中间件并添加到项目

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

# 创建app/middleware.py并编辑from django.http import JsonResponseclass 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.pyfrom django.http import JsonResponsedef json_response(request): print('json_response') err = 3 / 0 return JsonResponse({"msg": "ok", "code": 0})

添加到路由

# middleware/urls.pyfrom app.views import json_response, view_responseurlpatterns = [ ... 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 ''))

参考: https://docs.djangoproject.com/zh-hans/2.1/topics/http/middleware/

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表