The Hidden Cost of A 500 Internal Server Error

Sheldon Warkentin
April 1, 2021
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.

Web APIs are everywhere! We interact with APIs every day. We use APIs to write a tweet, discover music, make a purchase, or anything else you can imagine. We write applications that are composed with other APIs using patterns such as API Gateways.

It is empowering to interact with a well-designed and documented API to build the right solutions for yourself and your customers.

A well-behaved API will use HTTP response status codes to let you know if you are doing something right (200-209) or wrong (400-499).

If an API responds to you in the 4xx range, you can usually solve the problem yourself by adjusting your request. A helpful API will respond with some clues on what you need to do to solve the problem. For instance:

HTTP/1.1 400 Bad Request
Content-Type: application/json

{
"timestamp": "2021-03-16T18:57:30.918+00:00",
"status": 400,
"error": "Bad Request",
"message": "Missing required field, 'name'.",
"path": "/pets"
}

In the example above, the response tells us that we are missing a 'name' field. We just need to update the request body and try again.

Over time, you will eventually get a different response... 🙀

HTTP/1.1 500 Internal Server Error

{
"timestamp": "2021-03-16T18:57:30.918+00:00",
"status": 500,
"error": "Internal Server Error",
"message": "",
"path": "/foo"
}

500 Internal Server Error

The response might have some helpful information included, but will usually be some opaque text telling you that something went wrong. Was there something wrong with your request? Did you use an incorrect URL? You may encounter a 500 when interacting with the API on a web page that is provided by the API vendor; with the 500 buried in an XHR response.

Every consumer of the API now has to go through some or all of these steps:

  • Look closely at the request for obvious errors and try again
  • Start looking on stack overFlow/Google/etc for similar issues
  • Contact support and wait...
  • Maybe it was just temporary? -- try the request again
  • A retry might also be dangerous - Did the request partially complete? Will my credit card be double-billed now?

This cost, in terms of time and frustration, is compounded by every consumer that runs into the 500 response code with the API. The feeling of empowerment that developers gained using the API will start to fade away.

What causes a 500 Internal Server Error?

Many 500 Internal Server Errors are simply due to a lack of error handling in the implementation. Validation may be missing in some resource requests. Some input may fail to deserialize correctly such as a path or query parameter mismatch with the expected variable type.

Some 500s may be totally out of a developer's control such as failing infrastructure.

Other API errors may be indicative of something more serious (or security-related) happening such as SQL Injection or insecure deserialization.

API Fuzzing to the rescue!

API developers can try to find these issues early with negative testing. Without sufficient planning, negative testing is often ignored as most testing emphasis is placed on positive testing; ensuring an API does what it should on the happy path.

This is where fuzzing comes in! API Fuzzing is a technique where a comprehensive suite of inputs is generated to test an API. By using fuzzing techniques to generate inputs and observing the response from the application, an API fuzzer can quickly iterate through multitudes of test cases to find weakness in an API’s functionality or security.

When fuzzing an API, we should consider any 500 Internal Server Errors as 'buggy' endpoints. They are at minimum a waste of time for our customers and API owners to deal with, and at worst a possible symptom of serious underlying issues.

Mayhem

Mayhem is an API and code testing solution that uses fuzzing along with several other security testing techniques. You can use Mayhem to fuzz an API that is documented with a swagger/OpenAPI specification or Postman collection. You can start fuzzing your APIs today totally free for 30 days!

{{api-cta}}

The tool will report any 500 errors it discovers - along with the request that was sent and the response returned by the API.

Finding 500 Internal Server Error with Fuzzing

By running Mayhem as part of your build pipeline, you can spend your time solving real customer problems and let our security testing solution find 500 Internal Server Errors for you.

Other API Fuzzing tools

As API fuzzing grows in maturity - we will see lots of innovation in the space. Here are a few other tools that are in active development:

Happy fuzzing!

Share this post

How about some Mayhem in your inbox?

Subscribe to our monthly newsletter for expert insights and news on DevSecOps topics, plus Mayhem tips and tutorials.

By subscribing, you're agreeing to our website terms and privacy policy.
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.

Add Mayhem to Your DevSecOps for Free.

Get a full-featured 30 day free trial.

Complete API Security in 5 Minutes

Get started with Mayhem today for fast, comprehensive, API security. 

Get Mayhem

Maximize Code Coverage in Minutes

Mayhem is an award-winning AI that autonomously finds new exploitable bugs and improves your test suites.

Get Mayhem