zoukankan      html  css  js  c++  java
  • django基础知识之中间件:

    中间件

    • 是一个轻量级、底层的插件系统,可以介入Django的请求和响应处理过程,修改Django的输入或输出
    • 激活:添加到Django配置文件中的MIDDLEWARE_CLASSES元组中
    • 每个中间件组件是一个独立的Python类,可以定义下面方法中的一个或多个
      • _init _:无需任何参数,服务器响应第一个请求的时候调用一次,用于确定是否启用当前中间件
      • process_request(request):执行视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
      • process_view(request, view_func, view_args, view_kwargs):调用视图之前被调用,在每个请求上调用,返回None或HttpResponse对象
      • process_template_response(request, response):在视图刚好执行完毕之后被调用,在每个请求上调用,返回实现了render方法的响应对象
      • process_response(request, response):所有响应返回浏览器之前被调用,在每个请求上调用,返回HttpResponse对象
      • process_exception(request,response,exception):当视图抛出异常时调用,在每个请求上调用,返回一个HttpResponse对象
    • 使用中间件,可以干扰整个处理过程,每次请求中都会执行中间件的这个方法
    • 示例:自定义异常处理
    • 与settings.py同级目录下创建myexception.py文件,定义类MyException,实现process_exception方法
    from django.http import HttpResponse
    class MyException():
        def process_exception(request,response, exception):
            return HttpResponse(exception.message)
    
    • 将类MyException注册到settings.py中间件中
    MIDDLEWARE_CLASSES = (
        'test1.myexception.MyException',
        ...
    )
    
    • 定义视图,并发生一个异常信息,则会运行自定义的异常处理
  • 相关阅读:
    MySQL中文显示乱码
    mysql 存储引擎 InnoDB 与 MyISAM 的区别和选择
    mysql 分表的3种方法
    mysql 清空或删除表数据后,控制表自增列值的方法
    MySQL 下优化SQL语句的一些经验
    mysql 常用命令
    MySQL获得指定数据表中auto_increment自增id值的方法及实例
    SQL Server Alwayson创建代理作业注意事项
    LinkedList子类与Queue接口
    List接口
  • 原文地址:https://www.cnblogs.com/huwei934/p/6978744.html
Copyright © 2011-2022 走看看