为什么不同的Etags用于同一资源的不同表示?

ert*_*rne 14 rest etag

我理解使用etags进行乐观并发控制(例如在RESTful风格的体系结构中),并且我已经读过etags对于同一资源的不同表示应该是不同的.这是为什么?

最终,我们是否有兴趣了解资源是否已更改,以便我们可以处理并发修改?我甚至很难想象资源的表示会在没有资源本身变化的情况下发生变化,所以我显然缺少一些基本的理解.

ano*_*non 10

好问题,我认为这是一个有争议的问题.

我认为大多数人会说ETag不仅代表资源版本,还代表内容类型.这对于根据内容类型,语言等缓存响应是有意义的.

查看以下链接:


And*_*lau 5

当您列出事实或阅读 HTTP&HTTPbis 规范时,这不是一个争论的问题。

ETag 是一种缓存和并发控制的手段。弱 ETag 只是穷人缓存的一种手段。

在缓存 (GET) 方面 - uri + content-type + etag 可以帮助您节省带宽,方法是不响应有效负载,而仅响应 304 状态代码。

在并发控制(POST;PUT;PATCH)方面 - 根据 URI + 内容类型 + 位精确的响应负载计算 ETag 是浮躁的。为什么?

  • 如果您基于整个对象(响应负载的超集)计算 ETag(即您的负载给出 a+b,但该对象实际上是 a+b+c),那么例如执行 PATCH 将最终失败,因为ETag 已更改...您刷新...您获得相同的数据,但 ETag 不同...您使用新的 ETag 重试 PATCH,现在它可以工作了。失败
  • 如果您根据有效负载的子集计算 ETag,实际上会迫使用户无法控制不安全调用的条件,而完全不透明。即使与该 ETag 关联的数据已更改,PATCH 也会成功,这显然不是 HTTP 请求的预期方式。失败

条件请求应使用类似于“鉴于我的世界观仍然相同,然后执行请求。否则失败”的语义来处理。我的世界观是由过去的响应(URI + 标头 + 有效负载)构成的。