drf : 请求(Request)与响应(Response),全局设置和局部设置drf的默认配置项。

请求(Request)与响应(Response)

请求(Request),当次的HTTP响应请求到Django中被封装成python中的对象

  • request.data - POST, PUT请求的数据
  • request.query_params -GET请求的数据

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

REST framework 提供了Parser解析器,在接收到请求后会自动根据Content-Type指明的请求数据类型(如JSON、表单等)将请求数据进行parse解析,解析为类字典[QueryDict]对象保存到Request对象中。

Request对象的数据是自动根据前端发送数据的格式进行解析之后的结果。

无论前端发送的哪种格式的数据,我们都可以以统一的方式读取数据。

响应(Response),主要:data(HTTP的响应体),status(状态码),headers(HTTP的响应头)

rest_framework.response.Response
  • 继承关系 ---> SimpleTemplateResponse ---> django的HttpResponse

构造方式

Response(data, status=None, template_name=None, headers=None, content_type=None)

data数据不要是render处理之后的数据,只需传递python的内建类型数据即可,REST framework会使用renderer渲染器处理data

data不能是复杂结构的数据,如Django的模型类对象,对于这样的数据我们可以使用Serializer序列化器序列化处理后(转为了Python字典类型)再传递给data参数。

参数说明:

  • data: 为响应准备的序列化处理后的数据;
  • status: 状态码,默认200;
  • template_name: 模板名称,在浏览器访问看达到的模板,如果使用HTMLRenderer 时需指明;
  • headers: 用于存放响应头信息的字典;
  • content_type: 响应数据的Content-Type,通常此参数无需传递,REST framework会根据前端所需类型数据来设置该参数。

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

全局配置,在项目的settings.py 配置。

# 1. 后期 drf 的所有配置都写在这个字典中
# 2. drf有个默认配置文件(drf源码的--setting.py),如果没有写项目的配置文件,则使用内置的,写了优先使用项目的。
# 3. 返回样式的配置,一般不配置。
REST_FRAMEWORK = {
    'DEFAULT_RENDERER_CLASSES': (  # 默认响应渲染类
        'rest_framework.renderers.JSONRenderer',  # json渲染器
        'rest_framework.renderers.BrowsableAPIRenderer',  # 浏览API渲染器
    )
}

局部配置,只针对某个视图函数。

导入模块:

from rest_framework.renderers import BrowsableAPIRenderer, JSONRenderer
class BookView(APIView):
  	# 局部配置。尽管全局配置了,优先使用局部的。
    renderer_classes = [JSONRenderer]

    def post(self, request):
        print(request)
        ser = BookSerializers(data=request.data)
        if ser.is_valid():
            ser.save()
        return Response(ser.data)

    def get(self, request):
        book_list = Books.objects.all()
        # many=True 代表序列化多条数据
        ser = BookSerializers(instance=book_list, many=True)
        """
        <class 'rest_framework.serializers.ListSerializer'>
        ser 是ListSerializer的对象
        """
        print(type(ser))
        response = {'code': 100, 'msg': '查询成功', 'result': ser.data}
        #
        return Response(response, status=status.HTTP_202_ACCEPTED, headers={'name': 'junjie'})
posted @ 2022-04-01 19:25  谢俊杰  阅读(262)  评论(0编辑  收藏  举报