- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
尝试查看哪些模型最适合api
(更新少,但对象结构可能经常更改,高读取应用程序)
我有这样的资源
如果我只需要支持这些更新,
这有道理吗?
PATCH
与 application/merge-patch+json
RFC 7396
资源应与目标对象结构匹配
PATCH
with application/json
- 我倾向于选择这个,因为没有必要如此严格强制执行 RFC 7396
并灵活地更新更新规则。
要更新的自定义规则(但从技术上讲 - 我可以只发送需要更新的资源属性,类似于 application/merge-patch+json
)
PUT
与 application/json
资源应该匹配所有字段并创建新对象并替换(或作弊并仅像补丁中那样更新)
PUT
与 application/json
或者作弊,只像补丁中那样更新,但使用 put
最佳答案
从 REST 的角度来看,要记住的重要一点是统一的接口(interface) - 您拥有一些具有 application/json
表示形式的资源。我可以获取
您的表示,并使用我最喜欢的工具对其进行本地编辑。
如果我想建议更改资源以匹配我的表示,我们会从 HTTP 协议(protocol)中选择适当的方法。换句话说,HTTP 中的方法都是“通过网络传输此文档”域的一部分。 (引用:Jim Webber, 2011)。
实际上,支持“所有这些”是确保可以使用最广泛的通用客户端与您的资源进行交互的方法。
PUT /31E772D3-0157-4B52-8243-75EEAB946E65
Content-Type: application/json
完全合理的起点;它有几个优点 - 语义是 idempotent ,因此客户端知道丢失的请求可以重复,并且 HTTP PUT包括重要用例的语义,例如我们按原样接受您的表示,这可以让您减轻网络压力。
当表示远大于变化时,PUT 可能是一个不幸的选择。
PATCH /31E772D3-0157-4B52-8243-75EEAB946E65
Content-Type: ????
这是处理大表示的小变化的完全合理的方式。您放弃了 PUT 的一些优点 - 现在处理丢失的消息更加复杂。
PATCH /31E772D3-0157-4B52-8243-75EEAB946E65
Content-Type: application/json
没有任何可能。 application/json
不是 patch document格式——如果没有某种带外协议(protocol),您无法知道这种表示正在描述什么变化。
PATCH /31E772D3-0157-4B52-8243-75EEAB946E65
Content-Type: application/vnd.example.patch+json
PATCH /31E772D3-0157-4B52-8243-75EEAB946E65
Content-Type: application/prs.example.patch+json
这是执行前一点的“REST”方式;您定义自定义媒体类型并记录语义,然后任何实现您的媒体类型的客户端都可以使用它。 vendor tree和 vanity tree可用。 +json
位是 structured syntax name suffix ,它为无法识别基本子类型的消费者提供了结构提示。
PATCH /31E772D3-0157-4B52-8243-75EEAB946E65
Content-Type: application/json-patch+json
PATCH /31E772D3-0157-4B52-8243-75EEAB946E65
Content-Type: application/merge-patch+json
也是很好的选择,因为这两种类型已在 RFC 6902 中标准化和 RFC 7936 ;您更有可能让客户已经了解这些类型。
了解 HTTP 的客户端 PATCH想必也会知道如何使用 OPTIONS 方法来发现哪些方法和 patch document formats服务器已准备好处理。
OPTIONS /31E772D3-0157-4B52-8243-75EEAB946E65
HTTP/1.1 204 No Content
Allow: OPTIONS, GET, HEAD, PUT, PATCH
Accept-Patch: application/prs.example.patch+json, application/json-patch+json, application/merge-patch+json
关于java - patch 与 merge-patch 哪个更合适?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56030328/
我正在尝试使用 Android SDK 中的 Draw9Patch 工具,但在使用 Draw9Patch 打开我的图像后,它立即将我的所有图像区域显示为“坏补丁”。我手动绘制了定义可拉伸(stretc
我有一个运行补丁命令的构建工具,如果补丁命令返回非零值,它将导致构建失败。我正在应用一个可能已经或可能尚未应用的补丁,所以我使用 -N选项 patch ,它应该跳过。但是,当它确实跳过时,patch返
patching file chrome/browser/gpu_process_host_ui_shim.cc Unreversed patch detected! Skipping patch.
尝试查看哪些模型最适合api(更新少,但对象结构可能经常更改,高读取应用程序) 我有这样的资源 Epic(ID、名称、描述、开始日期、结束日期、状态、故事) 故事(ID、名称、说明、开始日期、结束日期
我创建了新问题,因为我觉得上一个问题已经得到解答,这属于一个新的地方。 我跑 bitbake core-image-minimal我收到以下错误: ERROR: systemd-1_232-r0 do
我正在使用 ColdFusion 10 与 PayPal 的服务器和 for some requests 进行通信我需要执行 HTTP PATCH 请求 are not supported by CF
我试图了解这两种模拟方法之间的区别。有人可以帮助区分它们吗?对于这个例子,我使用 passlib 库。 from passlib.context import CryptContext from un
WebTarget webTarget = httpClient.target(url); Invocation.Builder invocationBuilder = webTarget.reque
当提到“提交补丁”时,补丁这个词究竟是什么意思? 我已经看到它被大量使用,尤其是在开源世界中。它是什么意思,提交补丁到底涉及什么? 最佳答案 这是一个文件,其中列出了已更改的代码文件之间的差异。它通常
对于 matplotlib.patches,patch.contains_point(xy) 方法似乎与 patch.get_path().contains_point(xy) 不同,至少在拥有之后将
这是什么RFC 5789说: The PATCH method requests that a set of changes described in the request entity be ap
在 Draw 9-patch 中,一切看起来都很好。 但是,我的 SDK 说 9-patch png 格式不正确。因为我有类似 11-patch png 的东西。因为我不希望小抓取区域被缩放。如何让它
我创建了一个使用 javax.xml.ws.Endpoint 来创建 REST 端点的类: @WebServiceProvider @ServiceMode(value = javax.xml.ws.
语境 我有一个 spring boot (version 2.2.6.RELEASE) web 项目。 从这个 Web 应用程序(我称之为“APP1”)我想使用来自另一个 Web 应用程序的 PATC
在为我的应用程序编写单元测试时,我一直使用 @mock.patch 和 @patch.object 装饰器。但是现在,当我使用装饰器进行一些单元测试时,我收到错误消息“TypeError: stati
我在使用@mock.patch.object 函数时观察到 nosetests 的一个非常奇怪的行为: 当我同时运行多个测试时,我得到的结果与单独运行它们时不同。具体来说,在某些情况下,当我一起运行多
我正在使用 RestSharp v107。 我想更新测试用例的迭代路径。我可以使用 Postman 更新它,但使用 RestSharp 我收到“BAD Request”-“您必须在请求正文中传递有效的
我已经阅读了 GNU 项目中关于开源和其他许可证的文章。某些许可证允许您将更改发布为补丁,而不是完整的源代码(例如 Q 公共(public)许可证或 gnuplot 许可证)。这是什么意思?这样的补丁
有谁知道免费的优质补丁程序?您知道,可以将其中包含旧程序的目录放入其中,然后将其与具有新版本的目录进行比较,然后吐出一个补丁,这仅仅是两者之间的区别? 另外,我正在寻找可以修补整个目录的东西,而不仅仅
由于我当时一直在使用 Subversion 和 shell 工具,git-gui这些都是不可能的。是否有任何 shell 工具可以交互式地逐行应用补丁? 最佳答案 尝试通过 --dry-run选项 p
我是一名优秀的程序员,十分优秀!