APIView请求生命周期

2021-01-20 22:15

阅读:568

标签:处理   classes   方式   异常处理   渲染   log   ble   parser   exception   

今日总结

"""
1、APIView请求生命周期
APIView的as_view(局部禁用csrf) => 走父级的as_view调用dispatch分发请求 => APIView自己重写了dispatch,使用自己完成分发 => 分发前完成request二次封装、数据解析 => 三大认证 => 请求的实际响应(自己的视图类的处理分发) => 出现了异常,就会交给异常模块处理异常 => 响应模块完成响应、渲染模块可以json或浏览器两种方式渲染

2、请求模块:
    request._request 被 request完全兼容
    request.query_params | request.data
    
3、解析模块:
    局部配置:parser_classes = [JSONParser, FormParser, MultiPartParser]
    全局配置:
        'DEFAULT_PARSER_CLASSES': [
            'rest_framework.parsers.JSONParser',
            'rest_framework.parsers.FormParser',
            'rest_framework.parsers.MultiPartParser'
        ],
        
4、响应模块:
    Respose(data=常量|列表|字典, status=网络状态码)
    
5、渲染模块:
    局部配置:renderer_classes = [JSONRenderer, BrowsableAPIRenderer]
    全局配置:
        'DEFAULT_RENDERER_CLASSES': [
            'rest_framework.renderers.JSONRenderer',
            'rest_framework.renderers.BrowsableAPIRenderer',  # 上线后尽量关闭
        ],
        
6、异常模块
    settings中配置:'EXCEPTION_HANDLER': 'api.exception.exception_handler',
    重写exception_handler方法:
"""
# 一定要在settings文件中将异常模块配置自己的异常处理函数
from rest_framework.views import exception_handler as drf_exception_handler
from rest_framework.response import Response

# 先交个drf处理客户端异常,如果结果response为None代表服务器异常,自己处理
# 最终一定要在日志文件中记录异常现象
def exception_handler(exc, context):
    response = drf_exception_handler(exc, context)
    detail = '%s - %s - %s' % (context.get('view'), context.get('request').method, exc)
    if not response:  # 服务端错误
        response =  Response({'detail': detail})
    else:
        response.data = {'detail': detail}

    # 核心:要将response.data.get('detail')信息记录到日志文件
    # logger.waring(response.data.get('detail'))

    return response

APIView请求生命周期

标签:处理   classes   方式   异常处理   渲染   log   ble   parser   exception   

原文地址:https://www.cnblogs.com/jinhongquan/p/12120417.html


评论


亲,登录后才可以留言!