12 请求与响应

1.请求Request

 

 

 

 


# 请求对象
# from rest_framework.request import 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:前端post以三种编码方式传入的数据,都可以取出来
# 请求对象..query_params 与Django标准的request.GET相同,只是更换了更正确的名称而已。


#
属性: request.data request.query_params request._request 原来的request request.method --->就是使用了原来的request的method 通过重写 __getattr__魔法方法实现的 # 默认情况下post提交数据,可以三种方式(form-data,urlencoded,json),都能处理 # 我们只允许接口接收json格式,其他格式不支持 # 方式一:全局配置,在配置文件中 REST_FRAMEWORK = { # 默认能够解析的编码方式 'DEFAULT_PARSER_CLASSES': ( 'rest_framework.parsers.JSONParser', # json的 # 'rest_framework.parsers.FormParser', # urlencoded的 # 'rest_framework.parsers.MultiPartParser' # form-data的 ) } #方式二: 局部配置:(视图类) class PublishView(APIView): parser_classes = [FormParser,] # 优先级更高 # 优先级:先用视图类自己的,再用配置文件---》drf的默认配置

 

 

2.响应 Response

 

 


#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在这个路径下,它把所有使用到的状态码都定义成了常量
#template_name 渲染的模板名字(自定制模板),不需要了解
#headers:响应头,可以往响应头放东西,就是一个字典
#content_type:响应的编码格式,application/json和text/html;

# 浏览器响应成浏览器的格式,postman响应成json格式,通过配置实现的(默认配置)
#不管是postman还是浏览器,都返回json格式数据
# drf有默认的配置文件---》先从项目的setting中找,找不到,采用默认的
# drf的配置信息,先从自己类中找--》项目的setting中找---》默认的找
    -局部使用:对某个视图类有效

        -在视图类中写如下

        from rest_framework.renderers import JSONRenderer
        renderer_classes=[JSONRenderer,]

    -全局使用:全局的视图类,所有请求,都有效

        -在setting.py中加入如下

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



#
属性: data:返回给前端的数据,可以是字典,列表,字符串 status:响应状态码,1xx 2xx 3xx 4xx 5xx template_name : 不用,替换模板 headers=None :响应头 #默认用浏览器可以看到页面,用postman可以看到jon #只能显示json # 方式一:全局配置,在配置文件中 REST_FRAMEWORK = { # 使用的渲染类 'DEFAULT_RENDERER_CLASSES': ( 'rest_framework.renderers.JSONRenderer', # 'rest_framework.renderers.BrowsableAPIRenderer', ) } # 局部配置:(视图类) class PublishView(APIView): renderer_classes = [JSONRenderer,] # 优先级:先用视图类自己的,再用配置文件---》drf的默认配置

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2021-12-22 22:00  甜甜de微笑  阅读(36)  评论(0编辑  收藏  举报