- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
考虑一个没有副作用但以二进制数据作为参数的 Web API 方法。一个例子是一种方法,它告诉用户他们的图像是否经过 Photoshop 处理,但不会将图像或结果永久存储在其服务器上。
这样的方法应该是 GET
或 POST
?GET
似乎没有推荐的在 URL 参数之外发送数据的方法,但该方法的行为暗示了 GET
,根据 HTTP 规范,它用于安全、无状态的响应。这在 REST 语义下变得特别受限,这意味着 POST
方法在服务器上创建一个新对象。
最佳答案
This becomes particularly constraining under the semantics of REST, which imply that POST methods create a new object on the server.
POST
request 意味着发送的实体将被视为“由 Request-URI 标识的资源的新从属”,没有要求这会导致创建新的
永久对象或任何此类新对象都由 URI 标识(因此,就客户端而言,没有新对象)。一个对象可以是 transient 的,代表例如的结果“向数据处理过程提供数据块,例如提交表单的结果”,并且在表示该对象的实体被发送后不持久化。
POST
可以 创建一个新资源,当然是最好的方法,当服务器为新资源提供其 URI(当客户端指定新 URI 时,
PUT
是更合适的方法)它也可以是用于删除对象的情况(尽管再次删除可通过 URI 识别的单个*资源,那么
DELETE
更合适),创建和删除对象,更改多个对象,这可能意味着您的厨房灯会变但是无论成功还是失败,响应都是相同的,因为从网络服务器到厨房灯的通信不允许关于成功的反馈。它真的可以做任何事情。
GET
: 而松散的
POST
意味着我们可以为几乎每个请求为其提供一个案例(就像通过将 HTTP 用于类似 RPC 的协议(protocol)的方法所做的那样,本质上将 HTTP 视为一种传输协议(protocol)),这在理论上是不优雅的,在实践中效率低下并且定义笨拙。您有一个幂等函数,该函数仅取决于客户端感兴趣的内容,并且最明显地映射了
GET
在几个方面。
GET
会很容易。例如,我们可以定义一个简单的整数加法,例如
http://example.net/addInts?x=1;y=2
表示添加
71
和
2
因此成为代表数字 3 的永久不可变资源(因为
GET
的结果会随着资源的变化而变化,但该资源永远不会改变),然后使用像 HTML 的
<form>
这样的机制或 javascript 以允许服务器通知客户端如何构造其他号码的 URI(以维护 HATEOS 和/或 COD 约束)。简单!
1
那样简洁地表示的输入。和
2
可以上面。理论上你可以做类似
http://example.net/photoshoppedCheck?image=…
的事情并因此创建一个表示检查结果资源的 URI。该 URI 将在图像中每 3 个字节有 4 个字符。虽然对 URI 长度没有绝对限制,但理论和实践都允许这种情况失败(理论上 HTTP 允许代理和服务器对 URI 长度设置限制,实际上他们确实这样做了)。
GET
的论据。并以与使用
POST
相同的方式发送请求正文,有些网络服务器甚至允许您这样做。然而,
GET
被定义为返回一个实体,该实体描述了 URI 中标识的资源,并带有限制该实体如何进行描述的 header :由于请求正文不是该定义的一部分,所以
必须被您的代码忽略!如果您想改变这条规则,那么您必须考虑:
GET
一起发送。 . POST
之外我们唯一可以做的其他方法是有一个 URI,我们认为该 URI 代表未经过 Photoshop 处理的图像。因此,如果您
GET
你得到一个描述图像的实体(显然它可能是实际图像,但如果我们扩展内容协商的概念,它也可能是其他东西)然后
PUT
将检查图像,如果它被认为不是 photoshopped,它会以相同的图像和
200
响应。或者只是一个
204
而如果它被认为是经过Photoshop处理的,它会回复
400
因为我们已经尝试
PUT
作为资源的 photoshopped 图像只能是非 photoshopped 图像。因为我们立即响应,所以同时请求不存在竞争条件。
POST
将图像转换为固定 URI,然后返回一个描述分析的简单实体。
POST
基于该图像创建一个 transient 对象,然后用一个描述该对象的实体进行响应,然后该对象再次消失)。这是直接的。它尽可能高效(我们不能做任何 HTTP 缓存†,但大部分网络延迟将发生在上传而不是下载上)。它也适用于“处理某物”的一般用例,
POST
最初是为. (请记住,首先是 HTTP,然后 REST 描述了它为何如此有效,然后对 HTTP 进行了改进以更好地发挥这些优势)。
POST
当
GET
做任何事情时,
PUT
和
DELETE
(也许是 WebDAV 方法)会更好,不要害怕在那些不符合要求的情况下使用它的力量,并且不要认为“资源的新下属”必须意味着一个完整的长期 -活资源。
DELETE
很容易。这会删除多个对象,但是如果删除 X 会删除 A、B 和 C,那么如果您没有 X 或者您的 API 将无法理解,那么显然您不能拥有 A、B 或 C。通常,这归结为正在建模的内容,以及一件事取决于另一件事的明显程度。
关于rest - 对采用二进制数据的无效操作的正确 HTTP 请求方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27465116/
我正在尝试将谷歌地图集成到 Xamarin Android。但是,如标题中所写,收到错误。此错误出现在我的 SetContentView (Resource.Layout.Main); 上,如下所示:
在 Delphi 中如何以非文本模式打开二进制文件?类似于 C 函数 fopen(filename,"rb") 最佳答案 有几个选项。 1。使用文件流 var Stream: TFileStrea
我现在正在处理一个问题,如下所示: 有两个数字 x1 和 x2 并且 x2 > x1。 例如 x1 = 5; x2 = 10; 而且我必须在二进制表示中找到 x1 和 x2 之间的总和。 5 = 10
我有这个“程序集”文件(仅包含 directives ) // declare protected region as somewhere within the stack .equiv prot_s
有没有办法在powershell中确定指定的文件是否包含指定的字节数组(在任何位置)? 就像是: fgrep --binary-files=binary "$data" "$filepath" 当然,
我是一名工程师,而不是软件程序员,所以请原谅我的无知。 我编写了一个 Delphi(7SE) 程序,用于从连接到两个数字温度计的 USB 端口读取“真实”数据类型。 我已经完成了该计划的大部分内容。
我有一些代码,例如: u=(float *)calloc(n, sizeof(float)); for(i=1; i
typedef struct pixel_type { unsigned char r; unsigned char g; unsigned char b;
如何判断二进制数是否为负数? 目前我有下面的代码。它可以很好地转换为二进制文件。转换为十进制时,我需要知道最左边的位是否为 1 以判断它是否为负数,但我似乎无法弄清楚该怎么做。 此外,我如何才能让它返
我有一个带有适当重载的 Vect*float 运算符的 vector 类,我正在尝试创建全局/非成员 float*Vect 运算符,如下所示:(注意这是一个经过大量编辑的示例) class Vect
对于使用 C 编程的项目,我们正在尝试将图像转换为二进制数据,反之亦然。我们在网上找到的所有其他解决方案都是用 C++ 或 Java 编写的。这是我们尝试过的方法: 将图像转换为包含二进制数据的文本文
我需要对列表的元素求和,其中包含所有零或一,如果列表中有 1,则结果为 1,否则为 0。 def binary_search(l, low=0,high=-1): if not l: retu
我到处搜索以找到将 float 转换为八进制或二进制的方法。我知道 float.hex 和 float.fromhex。是否有模块可以对八进制/二进制值执行相同的工作? 例如:我有一个 float 1
当我阅读有关 list.h 文件中的 hlist 的 FreeBSD 源代码时,我对这个宏感到困惑: #define hlist_for_each_entry_safe(tp, p, n, head,
我不知道出了什么问题,也不知道为什么会出现此错误。我四处搜索,但我终究无法弄明白。 void print_arb_base(unsigned int n, unsigned int b) {
在任何语言中都可以轻松地将十进制转换为二进制,反之亦然,但我需要一个稍微复杂一点的函数。 给定一个十进制数和一个二进制位,我需要知道二进制位是开还是关(真或假)。 示例: IsBitTrue(30,1
在下面的代码中,我创建了两个文件,一个是文本格式,另一个是二进制格式。文件的图标显示相同。但是这两个文件的特征完全相同,包括大小、字符集(==二进制)和流(八位字节)。为什么没有文本文件?因为如果我明
我想通读一个二进制文件。谷歌搜索“python binary eof”引导我here . 现在,问题: 为什么容器(SO 答案中的 x)不包含单个(当前)字节而是包含一大堆字节?我做错了什么? 如果应
为什么只允许以 10 为基数使用小数点?为什么以下会引发语法错误? 0b1011101.1101 我输入的数字是否有歧义?除了 93.8125 之外,字符串似乎没有其他可能的数字 同样的问题也适用于其
boost 库中有二进制之类的东西吗?例如我想写: binary a; 我很惭愧地承认我曾尝试找到它(Google、Boost)但没有结果。他们提到了一些关于 binary_int<> 的内容,但我既
我是一名优秀的程序员,十分优秀!