博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django--中间件
阅读量:6176 次
发布时间:2019-06-21

本文共 2264 字,大约阅读时间需要 7 分钟。

一、中间件的执行过程

二、给中间件加三种方法对应的三种流程

三、自定义属于自己的中间件

四、中间件知识点总结

五、中间件的应用案例

---------------------------------------------------------------

一、中间件的执行过程

中间件:全局性的逻辑处理部分

介于request和response之间的处理程序
settings.py里的MIDDLEWARE就是中间件,有七个,有先后顺序

请求先到wsgiref被封装成request,

再到中间件,共七个
按顺序执行每个中间件的process_request()方法
从中间件出去后到了路由层,路由分发给相应的视图函数
处理完后
顺序执行中间件的process_response()方法
然后到了wsgiref,封装响应,交给浏览器

中间件调用流程: 

 

二、给中间件加三种方法对应的三种流程

情况一:

process_request里写return HttpResponse(..) 请求被拦截。见下图所示

情况二:

中间件里写了process_view(self, request,callback, callback_args, callback_kwargs)方法:

情况三:

 

三、自定义属于自己的中间件

在app01里新建my_middlewares.py

加到settings.py里的MIDDLEWARE
"app01.my_middlewares.CustomerMiddleware"
from django.utils.deprecation import MiddlewareMixin
class CustomerMiddleware(MiddlewareMixin):
  def process_request(self,request):
    print('request.....')
    #return HttpResponse("forbitton")   如果写这个就会拦截浏览器请求
  def process_response(self, request, response):
    print('response...')
    return response    #不响应要报错
    # 执行完中间件会依次执行各个中间件的process_view方法
    # callback是路由对应的视图函数,callback_args是视图函数的参数
  def process_view(self, request,callback, callback_args, callback_kwargs):
    # 下面这相当于执行对应的视图函数,得到响应再返回,就拦截了
    # response = callback(callback_args,callback_kwargs) 
    # return response
    print('process_view....')
  # 不出错不会执行这个,出错会依次执行中间件的这个方法,直到有中间件返回响应
  def process_exception(self,request,exception):
    print('process_exception...')
    return HttpResponse(exception)

四、中间件知识点总结

掌握:

1、process_request(self, request):中间件访问时执行的方法
2、process_response(self, request, response):中间件响应的时候执行的方法
3、执行流程
了解:
process_view
process_exception

五、中间件的应用案例

针对大多数视图要做的事情可以放在中间件里去做

例如校验是否登录,登录就执行视图函数。
例如限制一分钟内只能访问服务器20次,否则就屏蔽

中间件的应用案例:

1、做IP访问频率限制

某些IP访问服务器的频率过高,进行拦截,比如限制每分钟不能超过20次
2、URL访问过滤
如果用户访问的是login视图(放过)
如果访问其他视图,要检测是否有session认证,已经有了就放行,没有就返回login,
这样就省得在多个视图函数上写装饰器了

先在settings.py里定义白名单:WHITE_LIST['login/','reg/','logout/']

class AuthMiddleware(MiddlewareMixin):
  def process_request(self,request):
    white_list = settings.WHITE_LIST
    if request.path in white_list:
      return None       # 先判断路径是不是白名单的。如果路径在白名单里,就结束这个方法,即放行
    if not request.user.is_authenticated:
      return redirect("/login/")    # 再判断是否登录,未登录的让其登录

 

posted on
2019-04-20 02:11 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/staff/p/10739732.html

你可能感兴趣的文章
3.UIImageView+category
查看>>
2.UIView+category
查看>>
Android ImageLoader使用
查看>>
LDTP
查看>>
StringUtils工具类的常用方法
查看>>
linux下VNC安装与配置
查看>>
URL编码
查看>>
光模块及光纤知识(含分类,常用类型介绍)
查看>>
Apache 单IP多端口设置
查看>>
安装系统前的准备---vmware
查看>>
Tiny并行计算框架之使用介绍
查看>>
Linux od命令
查看>>
一个不错的MySQL集群管理工具
查看>>
mysql-proxy 按表分发查询的lua脚本
查看>>
在wordpress主题下面添加二级菜单
查看>>
CentOS 下JDK安装
查看>>
Nginx + Django
查看>>
我的友情链接
查看>>
用shell脚本编写进度条
查看>>
使用Live555类库实现的网络直播系统
查看>>