我了解 etags 用于乐观并发控制(例如,在 RESTful 架构风格中),并且我读过 etags 对于同一资源的不同表示应该是不同的。这是为什么?
最终,我们难道不是有兴趣知道资源是否已更改,以便我们可以处理并发修改吗?我什至很难想象资源的表示何时会发生变化而资源本身不会发生变化,所以我显然缺少一些基本的理解。
好问题,我认为这是一个有争议的问题。
我想大多数人会说 ETag 不仅代表资源版本,还代表内容类型。这对于基于内容类型、语言等缓存响应是有意义的。
查看以下链接:
当您列出事实或阅读 HTTP&HTTPbis 规范时,这不是一个争论的问题。
ETag 是一种缓存和并发控制的手段。弱 ETags 只是穷人缓存的一种手段。
在缓存 (GET) 方面 - uri + content-type + etag 也可以通过不响应有效负载而仅响应 304 状态代码来帮助您节省带宽。
在并发控制(POST;PUT;PATCH)方面 - 根据 URI + 内容类型 + 位精确响应有效负载计算 ETag 是浮躁的。为什么?
条件请求应该使用类似于“鉴于我的世界观仍然相同,然后执行请求。否则失败”的语义来处理。我对世界的看法是由过去的响应(URI + 标头 + 有效负载)构成的。