django框架-DRF视图中的request和response
1.Request
相对于django框架,DRF工程的request类则是继承自HttpRequest类,Rest framework提供了parser解释器,用来解释请求中的content_type中的请求数据类型例如json、表单等。将请求数据进行parser解析,解析成类字典对象保存到request对象中。
Request对象的数据就是根据前端传递过来的数据,进行解析之后形成的新的数据结构形式数据。优点:无论前端发送的是哪一种数据形式,都可以根据parser解释器来进行解析。
常用的方法:request.data(返回解析之后的请求体)
- 包含了解析之后的文件和非文件数据
- 包含了对POST、PUT、PATCH请求方式解析后的数据
- 利用了REST framework的parsers解析器,不仅支持表单类型数据,也支持JSON数据
request.query_params(和request.GET用法一致,只是名字不相同)
2.Response
同理的,Rest framework也提供了一个响应类Response,使用该类来构造响应对象时,响应的具体数据内容会被render渲染(不同于flask中的render)成符合前端的类型
REST framework同时也提供了一个渲染的工具Renderer,根据请求头中的Accept(接收数据类型声明)来自动转换响应数据的相对于数据形式。如果前端请求中未进行Accept声明,则会采用默认方式处理响应数据,我们可以通过配置来修改默认响应格式。默认的格式为JSON
采用渲染器Renderer,需要在环境配置文件中进行相应的配置,配置如下:
REST_FRAMEWORK = {
'DEFAULT_RENDERER_CLASSES': ( # 默认响应渲染类
'rest_framework.renderers.JSONRenderer', # json渲染器
'rest_framework.renderers.BrowsableAPIRenderer', # 浏览API渲染器
)
}
然后构造方式:Response(data, status=None, template_name=None, headers=None, content_type=None)
data:是经过序列化器处理之后,Renderer渲染之前的数据
stutas:是状态码,默认为200
template_name:模板名称,如果使用HTMLRenderer时需要指明
headers:用于存放响应头的信息的字典
content_type:响应的数据格式
status_code:响应状态码的数字
content:是经过Renderer处理之后的数据