Thanks to visit codestin.com
Credit goes to developer.mozilla.org

Expect header

The HTTP Expect request header indicates that there are expectations that need to be met by the server in order to handle the complete request successfully.

When a request has an Expect: 100-continue header, a server sends a 100 Continue response to indicate that the server is ready or capable of receiving the rest of the request content. Waiting for a 100 response can be helpful if a client anticipates that an error is likely, for example, when sending state-changing operations without previously verified authentication credentials.

A 417 Expectation Failed response is returned if the server cannot meet the expectation, or any other status otherwise (e.g., a 4XX status for a client error, or a 2XX status if the request can be resolved successfully without further processing).

None of the more common browsers send the Expect header, but some clients (command-line tools) do so by default.

Header type Request header
Forbidden request header Yes

Syntax

http
Expect: 100-continue

Directives

There is only one defined expectation:

100-continue

Informs recipients that the client is about to send a (presumably large) message body in this request and wishes to receive a 100 Continue interim response.

Examples

Large message body

A client sends a request with Expect header and waits for the server to respond before sending the message body.

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

The server checks the headers and generates the response, where a 100 Continue instructs the client to send the message body:

http
HTTP/1.1 100 Continue

The client completes the request by sending the actual data:

http
[Video data as content for PUT request]

Specifications

Specification
HTTP Semantics
# field.expect

See also