Aplicación CRUD usando REST en JavaEE (II)
En esta ocasión continuo explicando la aplicación CRUD, utilizando peticiones REST, con JavaEE.
Recordar que tenéis el código fuente en https://github.com/chuchip/crudJavaEE
En la anterior entrada, que podéis ver en en http://www.profesor-p.com/2018/10/06/aplicacion-rest-en-javaee/ habíamos visto como consultar los lenguajes disponibles. Ahora vamos a ver como añadir nuevos, modificarlos y borrarlos.
- Funcion create
Como podéis observar lo primero es especificar el tipo de petición HTTP que se va a aceptar, en este caso POST. Especificamos que queremos tratar solo peticiones tipo JSON y ya declaramos la función, que recibe un objeto tipo Locales
Después comprobamos si ese Locale no exista en la base de datos , devolviendo una respuesta tipo CONFLICT en caso de que ya exista.
En caso contrario, insertamos en la base de datos con la función create
de la clase LocaleController, para despues devolver una respuesta tipo created (código 201) con la dirección donde se podría consultar el registro recién creado.
Y como siempre, una imagen mejor que cien palabras 😉
En este pantallazo podéis ver como se hace la petición POST, mandando en el cuerpo el objeto JSON, donde se especifica el código y el nombre. La aplicación devuelve un 201 como estado y Location vemos que tenemos “http://localhost:8080/restExample/api/locale/es-BO” que seria donde podemos consultar el registro recién creado.
- Funcion update
Con esta función se actualizara el registro mandado. Mirar como se solicita el código del país, ademas del objeto tipo locales . Esto es para comprobar que el objeto a modificar coincida con el código del país mandado. En caso contrario devolverá una excepción tipo BadRequestException la cual devolverá un código 400 (Bad Request).
Si todo va bien, devolvemos un código 200 (OK).
Aquí tenéis un pantallazo actualizando el registro anteriormente insertado.
- Funcion delete
Esta función sera tratada cuando la petición HTTP sea del tipo DELETE ya que así esta especificado en la etiqueta @DELETE y deberá recibir un parámetro con el código del país a borrar. Si el país en cuestión no existe devolverá un código error tipo NOT_FOUND y si es borrado correctamente, un 200 (OK).
Y con esto ya tendremos nuestra maravillosa aplicación CRUD, a través de peticiones REST.
La lógica de acceso a la base de datos no es diferente a como se haría en Spring o con cualquier otro framework, así que si tenéis curiosidad de lo que hay detrás, podéis bajaros el código fuente de mi página de GitHub.
¡¡ Hasta la próxima !!