drf的请求模块

  • drf的request是在wdgi的request基础上再次封装

  • wsgi的request作为drf的request一个属性:_request

  • 新的request对旧的request做了完全兼容

  • 新的request对数据解析更规范化:所有的拼接参数都能解析到query_params中,所有数据包都被解析到data中,query_params和data属于QueryDict类型,可以.dict() 转化成原生dict类型

    源码分析

  • drf的APIView类:重写了as_view(),但主体逻辑还是调用父类View的as_view(),局部禁用csrf认证,重点:所有继承drf的基本视图类APIView的视图类,都不在做csrf认证校验

  • drf的APIView类:重写了dispatch(),在内部对ruquest进行了二次封装:self.initialize_request(request,*args,**kwargs),

    实例:
    print(request)
    print(request._request.GET)
    print(request.META)
    print(request.META.get('HTTP_LLL'))
内部核心:
走drf的Request初始化方法__init__:self.request=request
drf的Request的getter方法__getattr__:先从self.request反射属性,没取到再冲drf的request中取

drf的渲染模块

  • 可以在视图类中通过renderer_classes类属性对该视图的数据影响渲染做匹配(局部匹配)

  • 可以在项目的配置文件的drf配置中通过DEFAULT_RENDERER_CLASSES对该视图的数据响应渲染做配置(全局配置)

  • 如果一个视图类在有全局配置下,还进行了局部配置,优先走自己的局部配置

    源码分析

  • 二次处理响应对象:APIView的dispatch方法-->self.finalize_response(request,response,*args,**kwargs)

  • 获取渲染类对象:进入finalize_response方法-->self.perform_content_negotiation(request,force=True)

  • 从配置文件中得到渲染类对象:perform_content_negotiation-->self.get_renderers()-->[renderer() for renderer in self.renderer_classes]

    局部:renderer_classes = [JSONRenderer,BrowsableAPIRenderer]
    
    全局:REST_FRAMEWORK = {
    # 渲染模块的全局配置:开发一般只配置json
    'DEFAULT_RENDERER_CLASSES': [
    'rest_framework.renderers.JSONRenderer',]

drf的解析模块

服务的对象是数据包数据

  • 可以在视图类中通过parser_classes类属性对该视图的数据包解析做配置(局部配置)

  • 可以在项目的配置文件的drf配置中通过DEFAULT_PARSER_CLASSES对该视图的数据包解析做配置(全局配置)

    源码分析

  • APIView的dispatch方法:self.initialize_request(request,*args,**kwargs)内部还提供了数据解析

  • self.get_parser_context(request)提供要解析的数据,self.get_parsers()提供解析的类对象(内部从配置中找解析类)

    局部:parser_classes = [JSONParser, MultiPartParser, FormParser]
    
    全局: REST_FRAMEWORK ={'DEFAULT_PARSER_CLASSES': [
    'rest_framework.parsers.JSONParser',
    'rest_framework.parsers.FormParser',
    'rest_framework.parsers.MultiPartParser'
    ]}

drf的异常模块

重写异常模块的目的是记录异常信息(项目上线)

  • 在settings的drf配置中配置EXCEPTION_HANDLER,指向自定义的exception_handler函数

  • drf出现异常了,都会回调exception_handler函数,携带异常对象和异常相关信息内容,在exception_handler函数完成异信息的返回以及异常信息的logging日志

    源码分析

  • 在APIView的dispatch方法中,有一个超大的try...except...,将代码运行异常都交给异常处理模块处理self.handle_exception(exc)

  • 从配置中映射出配置处理异常的函数(自定义异常模块就是自定义配置指向自己的函数):self.get_exception_handler()

  • 异常函数exception_handler(exc,context)处理异常,就会走自己的:先交给系统处理(客户端异常),系统没处理(服务器异常),再自己处理

    异常信息都需要被logging记录,所以需要自定义,drf只处理客户端异常,服务器异常需要手动处理,统一处理结果

    def exception_handler(exc, context):
    response = drf_exception_handler(exc, context) if response is None: # drf没有处理的异常(服务器异常)
    return Response(status=status.HTTP_500_INTERNAL_SERVER_ERROR, data={
    'status': 6,
    'exc': '%s' % exc
    }) # 项目阶段,要记录到日志文件
    return Response(status=response.status_code, data={
    'status': 7,
    # drf处理的客户端异常,原始处理方式是将异常信息放在response对象的data中,data的格式是{'datail': '具体的异常信息'}
    'exc': '%s' % response.data.get('detail')
    }) 全局:REST_FRAMEWORK ={['EXCEPTION_HANDLER': 'api.utils.exception_handler']}

    drf响应模块

    • Response类生成对象需要的参数,以及Response类的对象可以使用的属性

    • 参数:Response(data=响应的数据,status=响应的网络状态码,header=通过响应头再携带部分信息给前端)

    • 属性:response.data response.status_code response.status_text

      核心及源码

      源码:Response类的__init__方法
      核心:知道response对象产生可以传那些信息,response对象又是如何访问这些信息的

Drf模块详细分析的更多相关文章

  1. Linux可信计算机制模块详细分析之核心文件分析(8)tpm.c核心代码注释(中)

    /*设置TPM命令格式*/ ssize_t tpm_getcap(struct device *dev, __be32 subcap_id, cap_t *cap, const char *desc) ...

  2. python笔记之常用模块用法分析

    python笔记之常用模块用法分析 内置模块(不用import就可以直接使用) 常用内置函数 help(obj) 在线帮助, obj可是任何类型 callable(obj) 查看一个obj是不是可以像 ...

  3. 海思uboot启动流程详细分析(三)【转】

    1. 前言 书接上文(u-boot启动流程分析(二)_平台相关部分),本文介绍u-boot启动流程中和具体版型(board)有关的部分,也即board_init_f/board_init_r所代表的. ...

  4. Zepto核心模块源代码分析

    一.Zepto核心模块架构 Zepto核心模块架构图 该图展示了Zepto核心模块架构代码的组织方式.主要分为私有变量.函数和暴露给用户的所有api. Zepto核心模块架构代码 该图展示了Zepto ...

  5. ZIP压缩算法详细分析及解压实例解释

    最近自己实现了一个ZIP压缩数据的解压程序,觉得有必要把ZIP压缩格式进行一下详细总结,数据压缩是一门通信原理和计算机科学都会涉及到的学科,在通信原理中,一般称为信源编码,在计算机科学里,一般称为数据 ...

  6. 1125MySQL Sending data导致查询很慢的问题详细分析

    -- 问题1 tablename使用主键索引反而比idx_ref_id慢的原因EXPLAIN SELECT SQL_NO_CACHE COUNT(id) FROM dbname.tbname FORC ...

  7. LinkedList详细分析

    一.源码解析1. LinkedList类定义2.LinkedList数据结构原理3.私有属性4.构造方法5.元素添加add()及原理6.删除数据remove()7.数据获取get()8.数据复制clo ...

  8. android ListView 九大重要属性详细分析、

    android ListView 九大重要属性详细分析. 1.android ListView 一些重要属性详解,兄弟朋友可以参考一下. 首先是stackFromBottom属性,这只该属性之后你做好 ...

  9. C语言中的static 详细分析

    转自:http://blog.csdn.net/keyeagle/article/details/6708077/ google了近三页的关于C语言中static的内容,发现可用的信息很少,要么长篇大 ...

随机推荐

  1. 牛客CSP-S提高组赛前集训营5 赛后总结

    A.无形的博弈 心理题. 答案为\(2^n\),可感性理解结论的正确性. #include<bits/stdc++.h> #define LL long long const LL Mod ...

  2. C++——动态内存分配2-创建对象数组

    //创建对象数组 #include<iostream> using namespace std; class Point { public:        Point()       {  ...

  3. Linux系统搭建Java环境【JDK、Tomcat、MySQL】一篇就够

      前言:所有项目在完成开发后都会部署上线的,一般都是用Linux系统作为服务器的,很少使用Windows Server(大多数项目的开发都是在Windows桌面系统完成的),一般有专门负责上线的人员 ...

  4. logistic回归损失函数(非常重要,深入理解)

    2.2 logistic回归损失函数(非常重要,深入理解) 上一节当中,为了能够训练logistic回归模型的参数w和b,需要定义一个成本函数 使用logistic回归训练的成本函数 为了让模型通过学 ...

  5. 题解【AcWing271】杨老师的照相排列

    题面 经典的线性 \(\text{DP}\) . 设 \(dp_{a,b,c,d,e}\) 表示第 \(1\) 排有 \(a\) 个人,第 \(2\) 排有 \(b\) 个人, 第 \(3\) 排有 ...

  6. [LOJ144] DFS 序 1 - DFS序 线段树

    为熟悉机房键盘而划水 #include <bits/stdc++.h> using namespace std; #define int long long const int N = 4 ...

  7. Python之旅第四天(列表、元祖、字典和习题)

    第四天,感觉时间还是过得很快,今天内容确实有点多,关于list的方法实在是太多了,元组tuple感觉有点鸡肋,可能得到后面才知道他的作用吧,然后是字典,看了很多关于字典的介绍,但是这货到底是干啥用的一 ...

  8. Spring MVC3 + Ehcache 缓存实现

    转自:http://www.coin163.com/it/490594393324999265/spring-ehcache Ehcache在很多项目中都出现过,用法也比较简单.一般的加些配置就可以了 ...

  9. maven报错Non-resolvable parent POM---pom找不到parent

    没有配置relativePath属性,说明运行的时候使用的是默认的,所以它会在默认的pom父类中查找,而不会到我自己创建的里面进行寻找 参考链接:https://blog.csdn.net/qq_37 ...

  10. Jarvis OJ - 栈系列部分pwn - Writeup

    最近做了Jarvis OJ的一部分pwn题,收获颇丰,现在这里简单记录一下exp,分析过程和思路以后再补上 Tell Me Something 此题与level0类似,请参考level0的writeu ...