博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
django框架-DRF视图中的request和response
阅读量:7040 次
发布时间:2019-06-28

本文共 1230 字,大约阅读时间需要 4 分钟。

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处理之后的数据

 

转载于:https://www.cnblogs.com/zxh1297/p/9311386.html

你可能感兴趣的文章
工作中常用的 Linux 命令
查看>>
English Corner
查看>>
(最短路 SPFA)Invitation Cards -- poj -- 1511
查看>>
两数相加LeetCode
查看>>
java抽象类和接口区别
查看>>
构建Ruby开发环境(Windows+Eclipse+Aptana Plugin)
查看>>
Miao Xian 隐私政策
查看>>
三维实景下的南极科考站是什么样子?
查看>>
Linux利用scp命令来进行文件复制
查看>>
【LabVIEW技巧】你可以不懂OOP,却不能不懂封装
查看>>
《Programming in Lua 3》读书笔记(十五)
查看>>
PHP读取xlsx Excel 文件
查看>>
R语言模型中的加总偏误与内生性:一种数值模拟方法
查看>>
ajax进error的原因
查看>>
[数据结构]浅谈哈希表的冲突避免策略
查看>>
python全栈考试作业 2017-03-30
查看>>
easyshell 安装
查看>>
前端工程师的未来
查看>>
JDBC原理
查看>>
Firefly distributed模块的原理与twisted中PB远程调用协议
查看>>