• django middleware笔记


    1.自定义的middleware写好后,要注册在setting中。系统也自带若干middleware。

    MIDDLEWARE = [
        'django.middleware.security.SecurityMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'django.middleware.common.CommonMiddleware',
        'django.middleware.csrf.CsrfViewMiddleware',
        'django.contrib.auth.middleware.AuthenticationMiddleware',
        'django.contrib.messages.middleware.MessageMiddleware',
        'django.middleware.clickjacking.XFrameOptionsMiddleware',
        'demo.auth.AuthMiddleware',
        #拦截器,子系统携带token去SSO server(SSO_URL),通过token查询user信息,
        # 并把user放入request.session,    # 查不到user则token为假的,验证错误
    ]

    2. 看实例,定义在demo.auth.py 文件中的AuthMiddleware class ,在setting.py中已经注册

    要求:

    (1)中间件类须继承自 django.utils.deprecation.MiddlewareMixin中间件类须实现下列五个方法中的一个或多个:

    def process_request(self, request): 执行视图之前被调用,在每个请求上调用回None或HttpResponse对象

    def process_view(self, request, callback, callback_args,callback_kwargs): 调用视图之前被调用,在每个请求上调用,返回None或HttpResponse对象

    def process_response(self, request, response): 所有响应返回浏览器之前被用,在每个请求上调用,返回HttpResponse对象

    def process_exception(self, request, exception): 当处理过程中抛出异常时用,返回一个HttpResponse对象

    def process_template_response(self, request, response): 在视图刚好执行之后被调用,在每个请求上调用,返回实现了render方法的响应对象

    注: 中间件中的大多数方法在返回None时表示忽略当前操作进入下一项事件,

    当返HttpResponese对象时表示此请求结果,直接返回给客户端。

    典型应用场景:

    可以使用中间键来增加验证码
    在爬虫scrapy框架中可以使用中间键来增加User-Agent 或者随机生成代理。

    参考了博客:https://blog.csdn.net/zsx2541577860/article/details/95041082

  • 相关阅读:
    嵌入式系统编程和调试技巧
    使用Kotlin开发Android应用(II):创建新project
    2015 Multi-University Training Contest 2
    C#开发Unity游戏教程之游戏对象的属性变量
    Java开发project师案例-网络日志分析系统
    Flask
    Flask
    Flask
    Flask
    Flask
  • 原文地址:https://www.cnblogs.com/lxgbky/p/12131518.html
Copyright © 2020-2023  润新知