Django2.1.3 中间件使用详解
作者:ilyq 发布时间:2023-11-06 19:46:00
标签:Django2,中间件
环境
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/
来源:https://www.jianshu.com/p/0b35e71a8483


猜你喜欢
- 今天遇到多条件搜索,其中需要用到in查询,但是laravel不支持 [ 'type', 'in', '
- 一:模板要了解jinja2,那么需要先理解模板的概念。模板在Python的web开发中广泛使用,它能够有效的将业务逻辑和页面逻辑分开,使代码
- 在 vue 项目,有时请求返回的数据 中会有含有 \n 的字符串,如果直接渲染的话无法实现换行。 一、通过 css属性
- :is 动态组件使用 v-bind:is=”组件名”,会自动去找匹配的组件名,如果没有,则不显示;<div id="app&
- 在改进SQL Server 7.0系列所实现的安全机制的过程中,Microsoft建立了一种既灵活又强大的安全管理机制,它能够对用户访问SQ
- javascript:单行注释用//呵呵呵呵;多行注释用/*hdhdhdh*/javascript中区别大小写,定义变量使用关键字var,语
- 引言最近python语言大火,除了在科学计算领域python有用武之地之外,在游戏、后台等方面,python也大放异彩,本篇博文将按照正规的
- python自带日志管理模块logging,使用时可进行模块化配置,详细可参考博文Python日志采集(详细)。但logging配置起来比较
- 元素是文档结构的基础,在CSS中,每个元素生成了一个包含了元素内容的框(box,也译为“盒子”)。但是不同的元素显示的方式会有所不同,例如&
- 本篇介绍在执行MySQL线上变更时遇到的问题,表现为"更新JSON字段时,实际更新的值与SQL语句中的值不一致,JSON格式错误&
- 本文实例讲述了Python3实现取图片 * 定的像素替换指定的颜色。分享给大家供大家参考,具体如下:1、原始图片2、修改脚本:# -*- co
- 阅读Chapter 1 清单Chapter 2 标题总览:不但所有网页都需要有标题,而且如果标记正确的话,他们能为网页设计和易用性
- 通用形态学函数上篇博文,我们介绍了形态学的基础腐蚀与膨胀操作,而将腐蚀与膨胀结合起来进行组合,我们就能实现开运算,闭运算等复杂的形态学运算。
- Python之Selenium自动化爬虫0.介绍Selenium是一个Web的自动化测试工具,最初是为网站自动化测试而开发的,Seleniu
- SQL Server导出表到EXCEL文件的存储过程:*--数据导出EXCEL导出表中的数据到Excel,包含字段名,文件为真正的Excel
- 初学 Python 的开发者经常会发现很多 Python 函数中用到了 yield 关键字,然而,带有 yield 的函数执行流程却和普通函
- 在整个安装的过程中也遇到了很多的坑,故此做个记录,争取下次不再犯!我的整个基本配置如下:电脑环境如下:win10(64位)+CPU:E5-2
- 冒泡排序:顾名思义就是(较小的值)像泡泡一样往上冒,(大的值)往下沉。实现原理:依次将相邻两个数值进行比较,较小的数值移到左边,较大的数值移
- Python最基本的数据结构是序列(列表/元组)。一个序列中的每个元素都分配有一个数字- 它的位置或索引。第一个索引是0,第二个
- salt分发后,主动将已完成的任务数据推送到redis中,使用redis的生产者模式,进行消息传送#coding=utf-8import f