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'})
合集:
python_django
分类:
编程相关 / Python
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了