Tutorial Series (1): A Simple Todo List Api Server (3)
In this chapter, we will be implementing error handling and input validation.
Let’s first import the necessary components.
We will be implementing a TodoItem class which specify how we should validate inputs.
Now we have a form that takes two fields,
id can be null, and
name should be a string with
To make it automatically validate input body, all we have to do is two modifications on method declarations, following is an example on
First, we need to add
@valid decorator to tell our validator that this parameter should be validated, and change its declaration type to the class we implemented above. Thus, all those rules will be validated against request body.
Apply the same to
putItem. Now we have all our input validated;
The one problem with this api service is that it is not really
RESTful, all errors are not correctly returned to the user.
To achive so, we will implement a configuration class to implement error handling.
First, let’s create a file
config.ts, and import it in
index.ts, something like
import './config'. This makes sure configurations are applied.
Now, import all components that we are gonna use.
To provide autowirable objects globally, we need to have a configuration class.
Let’s first handle
Add following method to class
@Bean means this is injected as an instance not a class. Passing a string to it, makes us/
vader access it by name (since
NotFoundHandler is an
interface, which is psuedo, that is not generated in js).
In the handler, we make it returnning json response, this makes it easier to handle on client side.
Notice after we added validation, the server responds a
internal error to the client if wrong data were requested. It is because there is no handler for this type of error.
Add following to
This is the end of this project. Again, you can access all source codes for each chapter at https://github.com/t2ee/tutorial-series-1.
I hope you know a bit more of
@t2ee components by now. In the next series, we will be learning how to customize them.
See you soon!