Expect - HTTP 编辑

Expect 是一个请求消息头,包含一个期望条件,表示服务器只有在满足此期望条件的情况下才能妥善地处理请求。

规范中只规定了一个期望条件,即 Expect: 100-continue, 对此服务器可以做出如下回应:

  • 100 如果消息头中的期望条件可以得到满足,使得请求可以顺利进行的话,
  • 417 (Expectation Failed) 如果服务器不能满足期望条件的话;也可以是其他任意表示客户端错误的状态码(4xx)。

例如,如果请求中 Content-Length 的值太大的话,可能会遭到服务器的拒绝。

常见的浏览器不会发送 Expect 消息头,但是其他类型的客户端如cURL默认会这么做。

Header typeRequest header
Forbidden header nameno

语法

目前规范中只规定了 "100-continue" 这一个期望条件。

Expect: 100-continue

指令

100-continue
通知接收方客户端要发送一个体积可能很大的消息体,期望收到状态码为100 (Continue)  的临时回复。

示例

大消息体

客户端发送带有Expect消息头的请求,等服务器回复后再发送消息体。

PUT /somewhere/fun HTTP/1.1
Host: origin.example.com
Content-Type: video/h264
Content-Length: 1234567890987
Expect: 100-continue

服务器开始检查请求消息头,可能会返回一个状态码为 100 (Continue) 的回复来告知客户端继续发送消息体,也可能会返回一个状态码为417 (Expectation Failed) 的回复来告知对方要求不能得到满足。

规范

SpecificationTitle
RFC 7231, section 5.1.1: ExpectHypertext Transfer Protocol (HTTP/1.1): Semantics and Content

浏览器兼容情况

目前没有已知的浏览器会使用这个消息头。

参见

  • 417Expectation Failed
  • 100Continue

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

词条统计

浏览:82 次

字数:4499

最后编辑:7年前

编辑次数:0 次

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文