drf的请求及响应

 


1 请求

from rest_framework.request import Request

  REST framework 传入视图的request对象不再是Django默认的HttpRequest对象,而是REST framework提供的扩展了HttpRequest类的Request类的对象。

 
def __init__(self, request, parsers=None, authenticators=None,
                 negotiator=None, parser_context=None):
        # 二次封装request,将原生request作为drf request对象的 _request 属性
        self._request = request
    def __getattr__(self,item):
        return getattr(self._request,item)
 

  .data:前端以三种编码格式传入的数据都可以取出来

  .query_params:与Django标准的request.GET相同,只是更换了名称

  .META :其余的全部在这里面

2 响应

from rest_framework.response import Response
 
def __init__(self, data=None, status=None,
                 template_name=None, headers=None,
                 exception=False, content_type=None):
        
#data:你要返回的数据,字典
#status:返回的状态码,默认是200,
    -from rest_framework import status在这个路径下,它把所有使用到的状态码都定义成了常量
      eg(举例):
HTTP_201_CREATED = 201
HTTP_202_ACCEPTED = 202
#template_name 渲染的模板名字(自定制模板),不需要了解 
#
headers:响应头,可以往响应头放东西,就是一个字典
#content_type:响应的编码格式,application/json和text/html;

  REST framework提供了一个响应类Response,使用该类构造响应对象时,响应的具体数据内容会被转换(render渲染)成符合前端需求的类型。

  REST framework提供了Renderer 渲染器,用来根据请求头中的Accept(接收数据类型声明)来自动转换响应数据到对应格式。如果前端请求中未进行Accept声明,则会采用默认方式处理响应数据,我们可以通过配置来修改默认响应格式。

  可以在rest_framework.settings查找所有的drf默认配置项

 
REST_FRAMEWORK = {
    'DEFAULT_RENDERER_CLASSES': (  # 默认响应渲染类
        'rest_framework.renderers.JSONRenderer',  # json渲染器
        'rest_framework.renderers.BrowsableAPIRenderer',  # 浏览API渲染器
    )
}
 

  不管是postman还是浏览器,都返回json格式数据

  全局配置

 
-在setting.py中加入如下
        REST_FRAMEWORK = {
            'DEFAULT_RENDERER_CLASSES': (  # 默认响应渲染类
                'rest_framework.renderers.JSONRenderer',  # json渲染器
                'rest_framework.renderers.BrowsableAPIRenderer',  # 浏览API渲染器
            )
        }
 

  局部配置

-在视图类中写如下
        from rest_framework.renderers import JSONRenderer
        renderer_classes=[JSONRenderer,]

  drf的配置信息,先从自己类中找--》项目的setting中找---》默认的找

  

posted @ 2021-06-23 10:37  欧阳锦涛  阅读(33)  评论(0)    收藏  举报
TOP 底部