HTTP: The Basics Behind Every Web Request

HTTP (Hyper Text Transfer Protocol) is the backbone of the web, defining how clients request data from servers and how servers respond. As an application layer protocol, HTTP relies on TCP to ensure every bit of data reaches its destination. It's also a stateless protocol, meaning servers don't store client data by default.

For enhanced security, there's HTTPS, which combines HTTP with SSL (Secure Socket Layer) to encrypt data transfers.

HTTP methods are the tools for performing CRUD operations (Create, Read, Update, Delete):

  1. GET - Retrieve data.

  2. PUT - Update data.

  3. POST - Create new data.

  4. DELETE - Remove data.

HTTP Status Codes are the web's way of communicating the outcome of your requests. When your browser asks a server for a webpage, the server responds with a status code indicating success or failure.

Common HTTP status code classes:

  1. 1XX - Informational.

  2. 2XX - Success.

  3. 3XX - Redirection.

  4. 4XX - Client-side Error.

  5. 5XX - Server-side Error.

Detailed HTTP Status Codes:

1XX - Informational

  1. 100 (Continue) - Server received the request header; client should proceed with the request body.

  2. 101 (Switching Protocols) - Server agrees to switch protocols as requested.

  3. 102 (Processing WebDAV) - Server is processing the request but hasn't completed it yet.

  4. 103 (Early Hints) - Provides early hints for preloading resources.

2XX - Success

  1. 200 (OK) - Request succeeded.

  2. 201 (Created) - Request accepted; resource created.

  3. 203 (No Content) - Request successful, but no content to return.

  4. 204 (Accepted) - Request accepted, but the resource is from a non-primary source.

  5. 206 (Partial Content) - Partial resource sent, useful for byte-serving.

3XX - Redirection

  1. 301 (Moved Permanently) - Resource permanently moved.

  2. 302 (Found) - Resource temporarily moved.

  3. 303 (See Other) - Redirect to a different resource, often after a POST operation.

  4. 304 (Not Modified) - Resource unchanged since the last request, aiding in caching.

4XX - Client-side Errors

  1. 400 (Bad Request) - Request cannot be processed.

  2. 401 (Unauthorized) - Authentication required.

  3. 403 (Forbidden) - Client authenticated but lacks permission.

  4. 404 (Not Found) - Resource not found.

  5. 405 (Method Not Allowed) - HTTP method not allowed for the resource.

  6. 406 (Not Acceptable) - Server can't produce a response matching the client's request headers.

  7. 409 (Conflict) - Request conflicts with the current server state.

  8. 413 (Payload Too Large) - Request body too large for the server to process.

  9. 429 (Too Many Requests) - Client made too many requests in a given time frame.

5XX - Server-side Errors

  1. 500 (Internal Server Error) - Generic server-side error.

  2. 502 (Bad Gateway) - Invalid response from an upstream server.

  3. 503 (Service Unavailable) - Server temporarily unable to handle the request.

  4. 504 (Gateway Timeout) - Upstream server didn't respond in time.