RESR API (一)之Requests
Requests
如果您正在做基于REST的Web服务,您应该忽略request.POST。
- Malcom Tredinnick,Django开发团队
REST框架的Request类扩展了标准的HttpRequest,增加了对REST框架请求解析和请求认证的支持。
Request parsing
REST框架的Request对象提供了灵活的请求解析,允许您以与通常处理表单数据相同的方式处理JSON数据或其他媒体类型的请求。(REST framework's Request objects provide flexible request parsing that allows you to treat requests with JSON data or other media types in the same way that you would normally deal with form data.)
.data
request.data返回请求体的解析内容。这与标准的request.POST和request.FILES属性相似,除了:
- 它包括所有解析的内容,包括文件和非文件输入。
- 它支持解析除
POST以外的HTTP方法的内容,这意味着您可以访问PUT和PATCH请求的内容。 - 它支持REST框架的灵活的请求解析,而不只是支持表单数据。例如,您可以像处理表单数据那样处理JSON数据。
有关详细信息,请参阅解析器文档。
.query_params
request.query_params是request.GET的一个同义词,但表达的含义比request.GET更准确。
建议使用request.query_params,而不使用Django标准的request.GET。这样有助于让代码更准确和可读 - 因为任何HTTP方法类型可能包括query参数,而不仅仅是GET请求。
.parsers
The APIView class or @api_view decorator will ensure that this property is automatically set to a list of Parser instances, based on the parser_classes set on the view or based on the DEFAULT_PARSER_CLASSES setting.
通常您不需要访问此属性。
注意:如果客户端发送的内容格式不正确,则访问request.data可能会抛出ParseError。默认情况下,REST框架的APIView类或@api_view装饰器将捕获错误并返回400 Bad Request响应。
如果客户端发送的内容的类型不能被解析,那么将会抛出UnsupportedMediaType异常,默认情况下会被捕获并返回415 Unsupported Media Type响应。
Content negotiation
request公开了一些属性,允许您决定 the content negotiation stage 的结果。这允许您实现一些行为,例如为不同的媒体类型选择不同的序列化方案。
.accepted_renderer
由 the content negotiation stage 选择的 renderer实例。
.accepted_media_type
由 the content negotiation stage 接受的一个表示媒体类型的字符串。
Authentication
REST框架提供灵活的、per-request 的身份验证,使您能够:
- 对API的不同部分使用不同的身份验证策略。
- 支持使用多种认证策略。
- 提供与传入请求相关联的用户和token信息。
.user
request.user通常返回一个django.contrib.auth.models.User实例,尽管行为取决于正在使用的身份验证策略。
如果请求未经身份验证,request.user默认值为request.userdjango.contrib.auth.models.AnonymousUser的一个实例。
有关详细信息,请参阅认证文档。
.auth
request.auth返回任何其他的身份验证上下文。request.auth确切的行为取决于正在使用的身份验证策略,但它通常是被认证的请求token的一个实例。
如果该请求是未认证的或者不存在附加的上下文,request.auth的默认为None。
有关详细信息,请参阅认证文档。
.authenticators
The APIView class or @api_view decorator will ensure that this property is automatically set to a list of Authentication instances, based on the authentication_classes set on the view or based on the DEFAULT_AUTHENTICATORS setting.
通常您不需要访问此属性。
Browser enhancements
REST框架支持的几个浏览器增强功能,例如基于浏览器的PUT,PATCH和DELETE forms。
.method
request.method以大写字符串的形式返回request 的HTTP方法。
基于浏览器的PUT,PATCH而DELETEforms 显然被支持。
有关更多信息,请参阅浏览器增强文档。
.content_type
request.content_type返回一个表示HTTP请求体媒体类型的字符串对象,如果没有提供媒体类型,则返回一个空字符串。
通常您不需要直接访问请求的内容类型,因为您通常依赖于REST框架的默认请求解析行为。
如果您确实需要访问请求的内容类型,则应优先使用.content_type属性而不是request.META.get('HTTP_CONTENT_TYPE'),因为它为基于浏览器的非表单内容提供transparent 支持。
有关更多信息,请参阅浏览器增强文档。
.stream
request.stream 返回一个表示请求体内容的流。
通常您不需要直接访问请求的内容,因为您通常将依赖于REST框架的默认请求解析行为。
标准HttpRequest属性
Note that due to implementation reasons the Request class does not inherit from HttpRequest class, but instead extends the class using composition.
RESR API (一)之Requests的更多相关文章
- RESR API (三)之Views
Class-based Views Django's class-based views are a welcome departure from the old-style views. - Rei ...
- RESR API (二)之Responses
Responses 与基本的HttpResponse对象不同,TemplateResponse对象保留 the details of the context that was provided by ...
- [py]requests+json模块处理api数据,flask前台展示
需要处理接口json数据,过滤字段,处理字段等. 一大波json数据来了 参考: https://stedolan.github.io/jq/tutorial/ https://api.github. ...
- 从0开始学爬虫10之urllib和requests库与github/api的交互
urllib库的使用 # coding=utf-8 import urllib2 import urllib # htpbin模拟的环境 URL_IP="http://10.11.0.215 ...
- Python-第三方库requests详解
Requests 是用Python语言编写,基于 urllib,采用 Apache2 Licensed 开源协议的 HTTP 库.它比 urllib 更加方便,可以节约我们大量的工作,完全满足 HTT ...
- Getting Started with ASP.NET Web API 2 (C#)
By Mike Wasson|last updated May 28, 2015 7556 of 8454 people found this helpful Print Download Com ...
- [转载]Python-第三方库requests详解
Requests 是用Python语言编写,基于 urllib,采用 Apache2 Licensed 开源协议的 HTTP 库.它比 urllib 更加方便,可以节约我们大量的工作,完全满足 HTT ...
- HttpClient与APS.NET Web API:请求内容的压缩与解压
首先说明一下,这里的压缩与解压不是通常所说的http compression——那是响应内容在服务端压缩.在客户端解压,而这里是请求内容在客户端压缩.在服务端解压. 对于响应内容的压缩,一般Web服务 ...
- Requests:Python HTTP Module学习笔记(二)(转)
在上一篇日志中对Requests做了一个整体的介绍,接来下再介绍一些高级的用法,主要资料还是翻译自官网的文档,如有错漏,欢迎指正. 参考资料:http://docs.python-requests.o ...
随机推荐
- CSS3参数matrix(n,n,n,n,n,n)定义 2D 转换,使用六个值的矩阵。那这六个值分别代表了什么参数?
matrix( a, b, c, d, e, f );a 水平缩放b 水平倾斜c 垂直倾斜d 垂直缩放e 水平移动f 垂直移动
- 第二篇:请求库之requests,selenium
requests模块 一.介绍 #介绍:使用requests可以模拟浏览器的请求,比起之前用到的urllib,requests模块的api更加便捷(本质就是封装了urllib3) #注意:reques ...
- notepad++文档格式转化window、unix、MAC
切换
- 源于react里面constructor()和super()的使用
es5里面没有继承的话 //构造函数 function People(name,age){ this.age = age; this.name = name } let p1 = new People ...
- 020:reverse函数补充
补充reverse两点: 1.如若在反转url时,需要添加参数,那么可以传递 kwargs 参数到 reverse 函数中,实例代码如下: '}) ) 2.如若想添加查询字符串参数,则必须手动进行ur ...
- python+selenium封装UI自动化框架
seleinum框架 框架的思想: 解决我们测试过程中的问题:大量的重复步骤,用自动化来实现 1)配置和程序的分离 2)测试数据和程序的分离 3)不懂编程的人员可以方便使用:使用的 ...
- 13. ClustrixDB 基于时间点恢复
在不太可能发生灾难的情况下,可以在特定数据库.表或整个集群上执行ClustrixDB集群的某个时间点恢复.应该非常小心地处理这一问题. 先决条件 在你可以使用时间点恢复之前,你的集群应该有几个先决条件 ...
- PHP基础教程探讨一些php编程性能优化总结
兄弟连PHP培训 小编最近在做php程序的性能优化,一些经过测试后发现的东西就先记录下来,以备后用. 首先对于一些反应慢的操作或页面要跟踪处理一下,可以使用webGrind的方式看一下主要问题出在 ...
- UVa 11212 Editing a Book (IDA* && 状态空间搜索)
题意:你有一篇n(2≤n≤9)个自然段组成的文章,希望将它们排列成1,2,…,n.可以用Ctrl+X(剪切)和Ctrl+V(粘贴)快捷键来完成任务.每次可以剪切一段连续的自然段,粘贴时按照顺序粘贴.注 ...
- C++ 值传递、指针传递、引用传递
1.值传递 (1)形参是实参的拷贝(这句话说明形参和实参是两个实体),改变形参的值并不会影响外部实参的值. (2)从被调用函数的角度来说,值传递是单向的(实参->形参),参数的值只能传入,不能传 ...