我有一个每分钟更新一次数据的 Web 服务器,并且希望使该数据可供所有类型的客户端使用。为了减少带宽,我使用 IF-MODIFIED-SINCE 和/或 IF-NONE-MATCH 设置 PHP 脚本来支持条件 GET。这个想法是客户端可以每 30 秒轮询一次,从而确保他们不会错过任何内容,但也不会获得重复的数据。
这对于大多数类型的客户端来说都非常有效,并且我已经验证它可以与支持标准 HTTP 条件 GET 语义的客户端一起使用。
但它不适用于 JavaScript,因为 JSONP 会在 DOM 中插入一个 <script> 标签并让浏览器处理一些事情——并且 <script> 中不支持(至少我不知道)条件 GET > 标签。
因此我修改了 PHP 脚本以支持传递 etag 值。返回的数据包含该分钟唯一的 etag 值。当 JavaScript 客户端从服务器接收数据时,它会保存 etag 值,以便可以在后续请求中使用该值。请求采用以下形式:
http://api.mydomain.com/script.php?fmt=json&callback=jscallback&etag=ab79bc65e
如果数据的 etag 与传递的 etag 不匹配,则我发送新数据。
这一切都运行良好,并且使用 jQuery 进行编码非常容易。不过,我的困境是如果 etag 匹配该怎么办。我看到两个选择:
- 返回 HTTP 304(未修改)
- 返回 HTTP 200(正常),但返回的数据仅包含 header 信息(修改日期、etag 等),不包含实际数据项。
如果我执行第一个操作,那么 JavaScript 客户端代码就会大大简化。如果浏览器收到对注入(inject)的 <script> 标记的 304 响应,它似乎工作得很好。但是……这个解决方案让我有些困扰。我不知道它是什么,但似乎我依赖于可能特定于浏览器的行为。如果某些浏览器收到 304,则可能会决定报告错误。
执行第二个操作需要在服务器上进行更多的工作,稍微增加一些带宽,并且需要客户端检查数据以查看数据是否已更新。这对每个人来说都是更多的工作,但看起来更干净。
所以,回答我的问题。如果您正在编写一个 JavaScript 客户端来获取此数据,您会更喜欢哪个?一个永远不会调用你的“成功”回调的无声失败?或者是一个“成功”返回,其中没有任何数据(除了状态)?第三种选择?
最佳答案
在没有其他人讨论的情况下,我凭着自己的直觉实现了第二个选项。 Web 服务器返回 HTTP 200,数据包含“未修改”状态代码以及 header 信息,但没有记录。这使得 JavaScript 稍微复杂一些,但可以防止我依赖未记录的行为。
关于jsonp - 如何使用 JSONP 轮询更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3379933/