At some point in your REST endpoint implementation, you will need to return a non 200 response. Now, most implementations show how to implement this using exceptions. While this may seem like a nice approach (from a programming language point of view), exceptions can add overhead to the running JVM. This translates to ineffective use of resources of the JVM for supporting non 200 responses.
Here is a gist where you don’t use exceptions to return non 200 responses:
1
2
3
4
5
6
7
8
9
10
@RequestMapping("/{surveyId}")
public Survey findSurvey(@PathVariable String surveyId, HttpServletResponse response) {
log.info("Querying survey {}", surveyId);
Survey survey = repository.get(surveyId);
if (survey == null) {
log.warn("Survey {} was not found!", surveyId);
response.setStatus(404);
}
return survey;
}
A few things to note from this snippet:
- This is a Spring Boot implementation (Boot makes things so much simple)
- The
HttpServletResponse
is injected by Boot (Spring MVC), no need of additional setup. - Notice that the body return is null already, so the non 200 response makes more sense.
Please note that this is an implementation specific construct to support non 200 responses. Jersey and others also provide a non exceptional way to handle this scenario. Semantics of what the endpoint does (nouns non verbs, uniform contracts, interfaces, etc) are not part of the discussion. This is strictly an implementation description meant to support the abstraction defined by the given REST endpoint.