Spring Boot

SpringBoot

Tutorial SpringBoot: Open API y cómo agregarlo en Spring Boot

Spring Boot OpenAPI: documentación de API. Aprende a documentar APIs en Spring Boot utilizando OpenAPI con ejemplos prácticos.

Introducción a OpenAPI en Spring Boot

OpenAPI, anteriormente conocido como Swagger, es una especificación para la descripción de APIs REST de manera estándar y comprensible tanto para humanos como para máquinas. La integración de OpenAPI en un proyecto Spring Boot facilita la documentación y prueba de APIs, mejorando la colaboración y la calidad del desarrollo.

Crear un Proyecto Spring Boot con Spring Web

Para comenzar, crea un nuevo proyecto Spring Boot seleccionando Spring Web como dependencia. Este será tu punto de partida para desarrollar servicios REST y documentarlos con OpenAPI.

Añadir OpenAPI al Proyecto

Para integrar OpenAPI en tu proyecto, añade la siguiente dependencia al pom.xml. Esta dependencia habilita la documentación automática de la API utilizando OpenAPI 3.

<dependency>
    <groupId>org.springdoc</groupId>
    <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
    <version>2.3.0</version>
</dependency>

Visita springdoc.org para más información sobre la dependencia y sus configuraciones.

Crear un Controlador en Spring Boot

Desarrolla un controlador que exponga endpoints REST. Por ejemplo, un controlador simple que devuelve un String y otro que devuelve un objeto de una clase personalizada podría lucir así:

@RestController
public class MiControlador {

    @GetMapping("/texto")
    public String getTexto() {
        return "Ejemplo de texto";
    }

    @GetMapping("/objeto")
    public MiObjeto getObjeto() {
        return new MiObjeto("Ejemplo", 123);
    }

    static class MiObjeto {
        private String nombre;
        private int valor;

        // Constructor, getters y setters
    }
}

Arrancar el Proyecto y Visualizar la Documentación de la API

Una vez que tu proyecto esté corriendo, puedes acceder a la UI de Swagger para visualizar la documentación de tu API navegando a:

http://localhost:8080/swagger-ui/index.html

En esta interfaz, verás listados todos tus endpoints, modelos de datos, y podrás incluso probar las llamadas a la API directamente desde el navegador.

Diferencia entre Swagger y OpenAPI

Swagger: Se refiere al conjunto de herramientas de código abierto que se utilizan para diseñar, construir, documentar y utilizar APIs RESTful. Incluye la especificación Swagger (ahora OpenAPI), la UI de Swagger para visualizar la documentación de la API, Swagger Codegen para generar código de cliente y servidor, entre otras herramientas.

OpenAPI: Es la especificación utilizada para describir APIs RESTful. Originalmente parte de Swagger, la especificación fue donada a la Linux Foundation y renombrada como OpenAPI Specification (OAS). Define un estándar y un lenguaje neutral para describir la estructura de las APIs REST, facilitando su comprensión y utilización.

Esta lección te proporciona las bases para comenzar a trabajar con OpenAPI en proyectos Spring Boot, desde la configuración inicial hasta la documentación y prueba de tus APIs REST, aprovechando las herramientas y estándares actuales en el desarrollo de interfaces de programación de aplicaciones.

Certifícate en SpringBoot con CertiDevs PLUS

Ejercicios de esta lección Open API y cómo agregarlo en Spring Boot

Evalúa tus conocimientos de esta lección Open API y cómo agregarlo en Spring Boot con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.

Web y Test Starters

Spring Boot
Puzzle

Entidades JPA

Spring Boot
Test

Repositorios reactivos

Spring Boot
Test

Inserción de datos

Spring Boot
Test

Borrar datos de base de datos

Spring Boot
Test

Controladores Spring MVC

Spring Boot
Código

Backend API REST con Spring Boot

Spring Boot
Proyecto

Operadores Reactivos

Spring Boot
Puzzle

Controladores Spring REST

Spring Boot
Código

Uso de Spring con Thymeleaf

Spring Boot
Puzzle

Crear entidades JPA

Spring Boot
Código

Registro de usuarios

Spring Boot
Test

CRUD y JPA Repository

Spring Boot
Puzzle

Anotaciones y mapeo en JPA

Spring Boot
Puzzle

Integración con Vue

Spring Boot
Test

Consultas JPQL con @Query en Spring Data JPA

Spring Boot
Test

Open API y cómo agregarlo en Spring Boot

Spring Boot
Puzzle

Uso de Controladores REST

Spring Boot
Puzzle

API Specification

Spring Boot
Puzzle

Inyección de dependencias

Spring Boot
Test

Introducción a Spring Boot

Spring Boot
Test

Consultas JPQL con @Query en Spring Data JPA

Spring Boot
Puzzle

API Query By Example (QBE)

Spring Boot
Puzzle

Inyección de dependencias

Spring Boot
Código

Vista en Spring MVC con Thymeleaf

Spring Boot
Test

Servicios en Spring

Spring Boot
Código

Configuración de Vue

Spring Boot
Puzzle

Integración con Angular

Spring Boot
Test

API Query By Example (QBE)

Spring Boot
Test

API Specification

Spring Boot
Test

Controladores MVC

Spring Boot
Test

Métodos find en repositorios

Spring Boot
Test

Repositorios Spring Data

Spring Boot
Test

Inyección de dependencias

Spring Boot
Puzzle

Data JPA y Mail Starters

Spring Boot
Test

Configuración de Angular

Spring Boot
Puzzle

Controladores Spring REST

Spring Boot
Test

Configuración de Controladores MVC

Spring Boot
Puzzle

Asociaciones de entidades JPA

Spring Boot
Código

Actualizar datos de base de datos

Spring Boot
Test

Identificadores y relaciones JPA

Spring Boot
Puzzle

Verificar token JWT en peticiones

Spring Boot
Test

Login de usuarios

Spring Boot
Test

Integración con React

Spring Boot
Test

Configuración de React

Spring Boot
Puzzle

Asociaciones en JPA

Spring Boot
Test

Consultas JPQL

Spring Boot
Código

Todas las lecciones de SpringBoot

Accede a todas las lecciones de SpringBoot y aprende con ejemplos prácticos de código y ejercicios de programación con IDE web sin instalar nada.

Introducción A Spring Boot

Spring Boot

Introducción Y Entorno

Spring Boot Starters

Spring Boot

Introducción Y Entorno

Inyección De Dependencias

Spring Boot

Introducción Y Entorno

Controladores Spring Mvc

Spring Boot

Spring Web

Vista En Spring Mvc Con Thymeleaf

Spring Boot

Spring Web

Controladores Spring Rest

Spring Boot

Spring Web

Open Api Y Cómo Agregarlo En Spring Boot

Spring Boot

Spring Web

Servicios En Spring

Spring Boot

Spring Web

Crear Entidades Jpa

Spring Boot

Persistencia Con Spring Data

Asociaciones De Entidades Jpa

Spring Boot

Persistencia Con Spring Data

Repositorios Spring Data

Spring Boot

Persistencia Con Spring Data

Métodos Find En Repositorios

Spring Boot

Persistencia Con Spring Data

Inserción De Datos

Spring Boot

Persistencia Con Spring Data

Actualizar Datos De Base De Datos

Spring Boot

Persistencia Con Spring Data

Borrar Datos De Base De Datos

Spring Boot

Persistencia Con Spring Data

Consultas Jpql Con @Query En Spring Data Jpa

Spring Boot

Persistencia Con Spring Data

Api Query By Example (Qbe)

Spring Boot

Persistencia Con Spring Data

Repositorios Reactivos

Spring Boot

Persistencia Con Spring Data

Api Specification

Spring Boot

Persistencia Con Spring Data

Integración Con React

Spring Boot

Integración Frontend

Integración Con Vue

Spring Boot

Integración Frontend

Integración Con Angular

Spring Boot

Integración Frontend

Registro De Usuarios

Spring Boot

Seguridad Con Spring Security

Login De Usuarios

Spring Boot

Seguridad Con Spring Security

Verificar Token Jwt En Peticiones

Spring Boot

Seguridad Con Spring Security

En esta lección

Objetivos de aprendizaje de esta lección

  1. Comprender la importancia de OpenAPI (anteriormente conocido como Swagger) para la documentación de APIs REST en proyectos Spring Boot, y cómo facilita la interacción y comprensión sin necesidad de acceso al código fuente.
  2. Aprender a crear un proyecto Spring Boot con la dependencia de Spring Web y cómo añadir manualmente la dependencia de OpenAPI en el archivo pom.xml.
  3. Entender cómo desarrollar un controlador básico en Spring Boot que exponga endpoints REST, devolviendo tanto cadenas de texto simples como objetos de clases personalizadas.
  4. Familiarizarse con el proceso de arranque de un proyecto Spring Boot con OpenAPI integrado y cómo acceder a la documentación de la API y probar los endpoints a través de la interfaz de usuario de Swagger.
  5. Reconocer la diferencia entre Swagger y OpenAPI, entendiendo que Swagger se refiere al conjunto de herramientas de código abierto para trabajar con la especificación OpenAPI, la cual describe APIs RESTful de manera estándar y neutral.