Django2.1.3 中间件使用详解
2019/7/14 23:58:15
本文主要是介绍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 ''))
参考: https://docs.djangoproject.com/zh-hans/2.1/topics/http/middleware/
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持找一找教程网。
这篇关于Django2.1.3 中间件使用详解的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-24Python编程基础详解
- 2024-11-21Python编程基础教程
- 2024-11-20Python编程基础与实践
- 2024-11-20Python编程基础与高级应用
- 2024-11-19Python 基础编程教程
- 2024-11-19Python基础入门教程
- 2024-11-17在FastAPI项目中添加一个生产级别的数据库——本地环境搭建指南
- 2024-11-16`PyMuPDF4LLM`:提取PDF数据的神器
- 2024-11-16四种数据科学Web界面框架快速对比:Rio、Reflex、Streamlit和Plotly Dash
- 2024-11-14获取参数学习:Python编程入门教程