HTTP Status Code
Luke Stephens
Nov 3, 2023
Introduction to HTTP Status Code?
HTTP status codes are a standardized set of numerical responses used in web communication. They play a pivotal role in the interaction between a client (such as a web browser or an API consumer) and a server.
The Significance of HTTP Status Codes
These status codes are not just technical indicators; they offer critical insights into the health and accessibility of web resources. They help in debugging and optimizing web applications, ensuring a smoother user experience. Each status code provides a concise indication of what happened with a request, whether successful, redirected, encountering client or server errors, or in need of further action.
Categories of HTTP Status Codes
HTTP status codes are grouped into five classes, each defined by the first digit of the code:
1xx (Informational): These codes indicate provisional responses, primarily to inform the client that the request was received and is being processed. For example,
102 Processing
indicates that the server has received and is processing the request, but no response is available yet.2xx (Success): This class indicates that the client's request was accepted and processed successfully. Codes like
200 OK
and201 Created
are common examples, signaling successful retrieval of information or creation of a resource.3xx (Redirection): These codes signify that further actions are needed to complete the request. They are used for URL redirection.
301 Moved Permanently
and302 Found
are commonly used for resource redirection.4xx (Client Error): This group represents errors that originate from the client’s side.
400 Bad Request
indicates a general client error, while404 Not Found
is well-known for indicating that the requested resource is not available.5xx (Server Error): These codes indicate failures on the server’s part.
500 Internal Server Error
is a generic message used when no more specific message is suitable.
Common HTTP Status Codes and Their Meanings
Understanding the most commonly encountered HTTP status codes is crucial for web development and troubleshooting:
100 Continue:
This is an informational response indicating that the initial part of a request has been received and has not yet been rejected by the server. The server intends to send a final response after the request has been fully received. This is relevant for understanding the preliminary stages of a request, especially in API operations involving large data uploads.
Request
Response
Status Code 200 OK:
The request has succeeded, and the meaning of success depends on the HTTP method used. This is common in GET
requests.
Request
Response
Status Code 201 Created:
Indicates that the request has led to the creation of a new resource, often seen in POST
requests.
Request
Response
Status Code 204 No Content:
A successful status code implying the request was processed but there is no content in the response, commonly used in DELETE
requests.
Request
Response
Status Code 301 Moved Permanently:
Indicates a permanent redirection of a resource's URL, important for tracking changes in API endpoints.
Request
Response
Status Code 302 Found:
This status code indicates that the resource requested has been temporarily moved to a different URI. For API security, tracking these redirects is essential to understand the flow of requests and ensure they are not being redirected to malicious sites.
Request
Response
Status Code 307 Temporary Redirect
The HTTP 307 status code signifies that the requested resource is temporarily available at a different URI, and future requests should still use the original URI.
Request
Response
HTTP Status Code 400 Bad Request:
Signifies a client error, such as malformed request syntax.
Request
Response
HTTP Status Code 401 Unauthorized:
The request lacks valid authentication credentials, essential for access control.
Request
Response
Status Code 403 Forbidden:
The server refuses to authorize the request, a key indicator of access control enforcement.
Request
Response
Status Code 404 Not Found:
The server can't find the requested resource, often due to incorrect endpoint access.
Request
Response
405 Method Not Allowed:
The method is known but disabled for the requested resource.
Request
Response
429 Too Many Requests:
Indicates rate limiting, crucial for preventing API abuse.
Request
Response
451 Unavailable For Legal Reasons:
The resource is legally restricted, important for compliance and legal considerations in API usage.
Request
Response
500 Internal Server Error:
A general server error indicating possible vulnerabilities or system issues.
Request
Response
503 Service Unavailable:
Suggests the server is overwhelmed, potentially due to a DoS attack.
Request
Response
Best Practices for Using HTTP Status Codes
Proper usage of HTTP status codes is essential in API design and web development:
Clear Communication: Use specific status codes that accurately describe the outcome of a request. Avoid overusing generic codes like
200 OK
or500 Internal Server Error
.Error Handling: Implement robust error handling in your application. Use client error codes to guide users or clients on how to rectify their requests.
Documentation: Clearly document the status codes your API returns, especially for custom APIs where standard HTTP behaviors might be overridden or extended.
Troubleshooting with HTTP Status Codes
A deep understanding of these codes can significantly aid in diagnosing and fixing issues in web applications:
Identifying Client Issues: A series of
4xx
errors could indicate problems with the client requests, such as incorrect URLs (404 Not Found
), unauthorized access attempts (403 Forbidden
), or bad request formats (400 Bad Request
).Server-Side Troubleshooting:
5xx
errors highlight server-side problems. For instance, a503 Service Unavailable
error might indicate that the server is overloaded or under maintenance.
Conclusion
HTTP status codes are a fundamental part of web communication, providing essential feedback about HTTP requests. A comprehensive understanding and proper use of these codes are vital for developers, enhancing the efficiency and reliability of web applications and APIs.
Explore more from Akto
Blog
Be updated about everything related to API Security, new API vulnerabilities, industry news and product updates.
Events
Browse and register for upcoming sessions or catch up on what you missed with exclusive recordings
CVE Database
Find out everything about latest API CVE in popular products
Test Library
Discover and find tests from Akto's 100+ API Security test library. Choose your template or add a new template to start your API Security testing.
Documentation
Check out Akto's product documentation for all information related to features and how to use them.