HTTP

HTTP 101 Switching Protocols vs 401 Unauthorized

HTTP 101 (Switching Protocols) is a 1xx Informational response, while 401 (Unauthorized) is a 4xx Client Error response. 101 indicates that the server understands the Upgrade header field request and indicates which protocol it is switching to. In contrast, 401 means that the request requires user authentication. The response includes a WWW-Authenticate header indicating the authentication scheme.

Description

The server understands the Upgrade header field request and indicates which protocol it is switching to.

When You See It

When upgrading from HTTP/1.1 to WebSocket, or to HTTP/2.

How to Fix

This is normal behavior during protocol upgrades. Ensure your client supports the target protocol.

Description

The request requires user authentication. The response includes a WWW-Authenticate header indicating the authentication scheme.

When You See It

When accessing a protected resource without credentials or with expired tokens.

How to Fix

Include valid authentication credentials (API key, Bearer token, Basic auth) in the Authorization header.

Key Differences

1.

101 is a 1xx Informational response, while 401 is a 4xx Client Error response.

2.

HTTP 101: The server understands the Upgrade header field request and indicates which protocol it is switching to.

3.

HTTP 401: The request requires user authentication. The response includes a WWW-Authenticate header indicating the authentication scheme.

4.

You encounter 101 when when upgrading from HTTP/1.1 to WebSocket, or to HTTP/2.

5.

You encounter 401 when when accessing a protected resource without credentials or with expired tokens.

When to Use Which

For 101 (Switching Protocols): This is normal behavior during protocol upgrades. Ensure your client supports the target protocol. For 401 (Unauthorized): Include valid authentication credentials (API key, Bearer token, Basic auth) in the Authorization header.

Learn More