写点什么

什么时候 POSTing 状态合适?

  • 2009-04-23
  • 本文字数:1292 字

    阅读完需:约 4 分钟

一篇文章中, Tim Bray,审视了 Sun Cloud API 的第一版公众草稿所收到的反馈。 对于其中一些反馈他在文中作出了回应,对于如何对交互进行建模,例如以 RESTful 的方式创建一个 VM 集群,进行了探索。

他展示了在设计 Sun Cloud API 范畴中的几个场景,并问到用 POSTing 状态来建模这样的交互是否是一种合适的策略。

但你不是真正的在改变状态,你是在请求一系列特定动作的执行,作为其结果,该状态是否能获得期望的值皆有可能。实际上,当你触发部署开关,状态变为了部署中,在不可预知的一段时间之后,又改变为已部署。而重启操作这一经典例子,就是在机器旁边有一个红色的大开关,问题是如何按这个开关。

所以啊,我越想越觉得,这些资源就像是按钮,只有唯一定义的操作:按下。人们对于“只写资源”牢骚满腹,但我却觉得不存在什么问题,因为这非常准确。重启和停止按钮实际上没有任何状态,所以你不应该期待 GET 操作能得到什么有用的东西。

Bill de hóra 在 对这篇文章的回应中提供了例子,来说明 PUT 和 POST 两者何时相对于另一方来说更为合适。

什么时候 PUT 与 POST 的比较才真正有影响?据我所知,当你的资源代表着一个集合时,它是有影响的,而这也很普遍-文件夹,专辑列表,订阅种子,收集物,博客,标签云,订单,购物车-任何基于列表的结构。

他同时还展现了关于整个讨论更加实用的方面,并建议将 POSTting 表单作为一种可能的解决方案。

另一方面,很多很多人不会,不想,(有时候也不能)去关心 REST/HTTP/AtomPub 的秘密。所以我也考虑到我们需要模式和实践来帮助开发者上手。

但是到目前为止我并不确认在我们支持 REST 的社区阵营里对于部分的更新资源已经有了一个很好的普遍答案或是设计模式。除非是这样,不然我推测人们还是会回到使用表单 posting,因为它是最为简单和兼容的部署客户端库和 web 框架的方式。要不就这样。要不就为部分更新定义一些特定的媒体类型。

Roy Fielding 也对这篇文章作出了回应

在我的论文中没有特指的主要原因,是因为这些方法是作为 Web 架构定义的一部分,由 HTTP 来定义的,而不是 REST 架构风格(所定义的)。特定的方法定义 […] 对 REST 架构风格没有影响,所以对它们进行风格讨论非常困难。REST 对方法的唯一要求就是它们需要为所有的资源有着统一的定义 (例如,中介不必需要去了解资源的类型就可以理解请求的含义)。

只有当 POST 被用在有其它的方法理想适用的场合,才是一个问题。其它的方法对中介更有价值,因为它们说明了失效如何被自动处理以及中间缓存如何去优化它们的行为。POST 不具备这些特点,但这并不意味着我们离得开它。POST 在 HTTP 里为许多有用的目的而服务,包括主要目标:“这一行为不需要符合于标准。”

Roy 作出了总结:

我们没必要对于 HTTP 的每个状态改变都使用 PUT。REST 从没说过我们应该这样。[…] 我个人的话,对这些按钮我就使用 POST。API 可以对使用 POST 作出补偿,可以在响应中表示客户端应当刷新对更大资源状态的表象。换句话说,我会返回一个 303 响应,重定向回 VM 状态,这样客户端就知道状态已经改变了。

这里有原文, 以及社区的所作出的回应。

查看英文原文: When Is POSTing State Appropriate?

2009-04-23 02:531120
用户头像

发布了 133 篇内容, 共 36.9 次阅读, 收获喜欢 1 次。

关注

评论

发布
暂无评论
发现更多内容

开发者独立搭建一个跨模态搜索应用有多难?

Jina AI

深度学习 云原生 神经搜索 跨模态应用 多模态数据

大数据开发,Hadoop Spark太重?你试试esProc SPL

华为云开发者联盟

大数据 开源 后端

《分布式云最佳实践》分论坛,8月11日深圳见

阿里云弹性计算

分布式云 飞天 数字化升级 一云多形态

智能电视可以打开小程序应用,再也不用头痛内存了

Geek_99967b

小程序

如何通过使用“缓存”相关技术,解决“高并发”的业务场景案例?

冉然学Java

高并发 java; 单线程 redis'

从-99打造Sentinel高可用集群限流中间件

艾小仙

Java 高可用 sentinel 集群限流

化繁为简,聊一聊复制状态机系统架构抽象

阿里技术

数据库 架构

兆骑科创创新创业大赛活动举办,线上直播路演,投融资对接

兆骑科创凤阁

并发程序的隐藏杀手——假共享(False Sharing)

了不起的程序猿

编程 高并发 java程序员

2022年7月国产数据库大事记-墨天轮

墨天轮

数据库 腾讯云 GaussDB 国产数据库 KingBase

SAP ABAP SteamPunk 蒸汽朋克的最新进展 - 嵌入式蒸汽朋克

汪子熙

云原生 Cloud 云平台 SAP 8月月更

【SpringBoot 一】SpringApplication启动类的Args详解

石臻臻的杂货铺

spring-boot 8月月更

【SpringBoot 二】spring.factories加载时机分析

石臻臻的杂货铺

springboot 8月月更

HTTP和HTTPS的区别

开发微hkkf5566

攻防视角下,初创企业安全实战经验分享

声网

网络安全

基于 Next.js实现在线Excel

葡萄城技术团队

前端 在线excel nextjs 表格 控件

如何防止重复下单?

三分恶

8月月更

Mybatis中#{}和${}的区别

开发微hkkf5566

IDC:阿里云稳居中国大数据平台公有云市场第一位

阿里云大数据AI技术

阿里云

《中国综合算力指数》《中国算力白皮书》《中国存力白皮书》《中国运力白皮书》在首届算力大会上重磅发出

GPU算力

快速打造安全的车联网平台

Geek_99967b

小程序

百度APP Android包体积优化实践(三)资源优化

百度Geek说

Andriod

《2022 年上半年全球独角兽企业发展研究报告》发布——DEMO WORLD世界创新峰会圆满落幕

创业邦

信创是什么意思?涉及哪些行业?为什么要发展信创?

行云管家

信息安全 信创

中大型商业银行堡垒机升级改造就用行云管家!必看!

行云管家

信息安全 银行 堡垒机 IT安全

使用python获取浏览器收藏夹和历史浏览记录,然后可以...

技能实验室

签约计划第三季

直播系统开发——直播间架构的设计及难点分析

开源直播系统源码

软件开发 语聊房 语音聊天源码 直播系统开发

Pisanix v0.2.0 发布|新增动态读写分离支持

SphereEx

数据库 开源 ShardingSphere SphereEx

重构指标之如何监控代码圈复杂度

京东科技开发者

测试 重构 软件重构 分布式应用软件

如何在Linux (CentOS7.3) 下安装JDK1.8?【一篇文章教会你】

Bug终结者

java; Linux Kenel 8月月更

Vue3 初探

怀府风

什么时候POSTing状态合适?_SOA_Dilip Krishnan_InfoQ精选文章