DEV Community

Cover image for HTTP Response Status Codes | All you need to know | 2025๐Ÿฑโ€๐Ÿ’ป
Kaustubh Joshi
Kaustubh Joshi

Posted on

HTTP Response Status Codes | All you need to know | 2025๐Ÿฑโ€๐Ÿ’ป

๐Ÿ˜„ Introduction

Most of the web developers in the tech industry are already familiar with different HTTP response status codes, like, 200 OK, 404 NOT FOUND, and so on. These status codes are important in understanding how your HTTP request has been processed on the server side.
This quick read will help you shed light on different response status codes that HTTP supports.

If you want to learn about HTTP Request Methods first, feel free to jump to: Hello, I'm HTTP and these are my request methods๐Ÿ‘‹๐Ÿป


๐ŸŒฒ Response classes/groups

In the very basic way, responses are categorized in the 5 different classes as follows:

Responses are divided into 5 classes

This way, you can easily get the idea on how your request has been processed on the server, just by looking at the first digit of the response code.

Birds eye view on response code classes


๐Ÿ“ถ HTTP Response Status Codes

Now let us get our hands dirty with each class:

Quick Guide:

WebDAV: Set of extensions to the Hypertext Transfer Protocol
Trash Icon --> Deprecated
Flask Icon --> Experimental
Star Icon --> Common/Important
ย 
I will not be covering Deprecated methods as they are no longer in use anymore.
Please visit the links attached in the Reference section to learn more about these methods.


Informational Responses

IR status codes

100 Continue

  • Tells client that their HTTP request is authorized to continue
  • Client should ignore this response if the request is already finished

101 Switching Protocols

  • This code is sent in response to an Upgrade request header from the client
  • Tells client the protocol, the server is switching to

103 Early Hints

  • This status code tells client to start pre-loading resources while the server prepares a response or preconnect to an origin from which the page will need resources
  • This status code is primarily intended to be used with the Link header

Successful Responses

Success status codes

200 OK ๐ŸŒŸ

  • The request succeeded
  • Meaning of "Success" changes as per HTTP request Method
    • GET => Resources has been fetched
    • HEAD => Representation headers fetched, no message body
    • PUT/POST => Result of the action performed is fetched in the message body
    • TRACE => The message body contains the request as received by the server

201 Created

  • The request succeeded, and a new resource was created as a result
  • Typically after HTTP POST or some PUT requests

202 Accepted

  • Notification heads-up to client that the request has been received but not yet acted upon
  • Used for cases where another process or server handles the request, or for batch processing

203 Non-Authoritative Information

  • This response code means the returned metadata is not exactly the same as is available from the origin server, but is collected from a local or a third-party copy

204 No Content

  • There is no content to send for this request, but the headers are useful

205 Reset Content

  • Tells the user agent to reset the document which sent this request

206 Partial Content

  • Used when the client requests only part of a resource

207 Multi-Status (WebDAV)

  • Conveys information about multiple resources, for situations where multiple status codes might be appropriate.

208 Already Reported (WebDAV)

  • Used to avoid repeatedly enumerating the internal members of multiple bindings to the same collection

218 This is Fine

  • This is an unofficial HTTP response that is used specifically by the Apache Web Server
  • Indicate that there is a HTTP client error or HTTP server error

226 IM Used (HTTP Delta encoding) ๐Ÿ‘€

  • The server has fulfilled a GET request for the resource, and the response is a representation of the result of one or more instance-manipulations applied to the current instance

Redirection Messages

Redirection status codes

300 Multiple Choices

  • The request has more than one possible response and the user agent or user should choose one of them

301 Moved Permanently ๐ŸŒŸ

  • The URL of the requested resource has been changed permanently
  • The new URL is given in the response.

302 Found

  • This response code means that the URI of requested resource has been changed temporarily
  • Further changes in the URI might be made in the future, so the same URI should be used by the client in future requests

303 See Other

  • The server sent this response to direct the client to get the requested resource at another URI with a GET request

304 Not Modified

  • This is used for caching purposes
  • It tells the client that the response has not been modified, so the client can continue to use the same cached version of the response

307 Temporary Redirect

  • Imagine 302 Found again but this time the HTTP method (i.e. GET, POST...) used in the first request must not change

308 Permanent Redirect

  • Imagine 301 Moved Permanently again but with the same restriction on HTTP method change

Client Error Responses

Client Error status codes

400 Bad Request ๐ŸŒŸ

  • The server cannot or will not process the request due to client error
  • Examples: malformed request syntax, invalid request message framing, or deceptive request routing

401 Unauthorized ๐ŸŒŸ

  • Semantically this response means "unauthenticated"
  • Meaning, the client must authenticate itself to get the requested response

402 Payment Required

  • The initial purpose of this code was for digital payment systems, however this status code is rarely used and no standard convention exists

403 Forbidden ๐ŸŒŸ

  • The client, although logged-in, does not have access rights to the content
  • That is, it is unauthorized, so the server is refusing to give the requested resource
  • Unlike 401 Unauthorized, the client's identity is known to the server

404 Not Found ๐ŸŒŸ

  • Most common status code in web community
  • The server cannot find the requested resource
  • In the browser, this means the URL is not recognized.
  • In an API, this can also mean that the endpoint is valid but the resource itself does not exist
  • Servers may also send this response instead of 403 Forbidden to hide the existence of a resource from an unauthorized client

405 Method Not Allowed ๐ŸŒŸ

  • The request HTTP method is known to the server but not supported for the target resource

406 Not Acceptable

  • Sent when content negotiation doesnโ€™t yield an acceptable content type

407 Proxy Authentication Required

  • Similar to 401 Unauthorized but here the Authentication is needed to be done by a proxy

408 Request Timeout ๐ŸŒŸ

  • Sent by server when the server would like to shut down unused or idle connections

409 Conflict

  • The request conflicts with the serverโ€™s current state

410 Gone

  • The requested content has been permanently deleted, with no forwarding address

411 Length Required

  • The server requires the Content-Length header field

412 Precondition Failed

  • The clientโ€™s preconditions are not met by the server

413 Content Too Large

  • The request body is too big for the limits defined by server

414 URI Too Long

  • Client has requested a URI which is longer than the server is willing to interpret

Client Error status codes 2

415 Unsupported Media Type ๐ŸŒŸ

  • The media format added in the request data is not supported by the server

416 Range Not Satisfiable

  • The ranges specified by the Range header field in the request cannot be fulfilled by the server

417 Expectation Failed

  • Indicate that the conditions set by the client using the Expect header can not be satisfied

418 I'm a teapot โ˜•

  • Indicate that this server has been requested to brew coffee, yet, itโ€™s a teapot

421 Misdirected Request

  • Client error sent by a server that is unable to produce a response
  • The client may retry the request using another connection.

422 Unprocessable Content (WebDAV)

  • The request was well-formed but was unable to be followed due to semantic errors

423 Locked (WebDAV)

  • The resource that is being accessed is locked

424 Failed Dependency (WebDAV)

  • The request failed due to failure of a previous dependent request

425 Too Early

  • Indicates that the server is unwilling to risk processing a request that might be replayed
  • Experimental

426 Upgrade Required

  • Indicate that it is unwilling to process the request using the current protocol
  • The server sends an Upgrade header in a this response to indicate the required protocol(s)

428 Precondition Required

  • Indicate that HTTP requests of this type must be made conditionally, yet no precondition was included

429 Too Many Requests

  • The user has sent too many requests in a given amount of time

431 Request Header Fields Too Large

  • The server is unwilling to process the request because its header fields are too large
  • The request may be resubmitted after reducing the size of the request header fields

451 Unavailable For Legal Reasons

  • The user agent requested a resource that cannot legally be provided
  • For example, a web page censored by a government

Server Error Responses

Server error status codes

500 Internal Server Error ๐ŸŒŸ

  • Most common status code
  • This means that server has encountered a situation where it does not know how to handle it
  • This error is generic, indicating that the server cannot find a more appropriate 5XX status code to respond with

501 Not Implemented

  • Usually tells that method is available on the server but is not yet implemented as of now
  • GET and HEAD methods are required to be supported by the server and therefore that must never return this code

502 Bad Gateway ๐ŸŒŸ

  • This error response means that the server, while working as a gateway to get a response needed to handle the request, got an invalid response

503 Service Unavailable

  • The server is not ready to handle the request
  • Common causes are a server that is down for maintenance or that is overloaded

504 Gateway Timeout ๐ŸŒŸ

  • This error response is given when the server is acting as a gateway to another resource and cannot get a response in time

505 HTTP Version Not Supported

  • The HTTP version used in the request is not supported by the server

506 Variant Also Negotiates

  • The server has an internal configuration error
  • and server can engage in transparent content negotiation

507 Insufficient Storage (WebDAV)

  • Storage capacity of server is unable to store the representation needed of the request to succsfully complete it

508 Loop Detected (WebDAV)

  • The server detected an infinite loop while processing the request

510 Not Extended

  • The client request declares an HTTP Extension (RFC 2774) that should be used to process the request, but the extension is not supported

511 Network Authentication Required

  • Indicates that the client needs to authenticate to gain network access

๐Ÿ˜ธ Learn from the experts (they are cats!)

Visit http.cat and learn the HTTP response status codes in a very unique way ๐Ÿ˜ผ

102 Processing


๐Ÿฎ Browser Compatibility

Browser Compatibility Table


๐Ÿฑโ€๐Ÿš€ Conclusion

This post might save you some time searching different web pages for getting an understanding on HTTP Response status codes.

I hope this post will help you in future, be it a help in your project or a last min study for your interview.

HAPPY CODING!!!โค๏ธ

I'm a Teapot


๐Ÿ“š References

Top comments (8)

Collapse
 
carban profile image
carban

I didn't know there are too many variations of response codes. Thank you

Collapse
 
elpidaguy profile image
Kaustubh Joshi

Welcome :)

Collapse
 
1hamzabek profile image
Hamza

Good hit! This definitely helps..However 418 was a new one!!

Collapse
 
elpidaguy profile image
Kaustubh Joshi

Thank you :)

Collapse
 
hasan_py profile image
Hasan

Good one.

Collapse
 
elpidaguy profile image
Kaustubh Joshi

Thanks ๐Ÿ‘๐Ÿป

Collapse
 
govind_prajapati_3707ef68 profile image
Govind Prajapati • Edited

I never thought that we have this many http responses. Definitely this is going to help me a lot.

Collapse
 
elpidaguy profile image
Kaustubh Joshi

Thanks !