Saltar al contenido principal

Spring Boot

Abrir en ChatGPT

Spring Boot es una opción popular para construir aplicaciones Java, proporcionando inyección de dependencia, auto-configuración y un modelo de servidor embebido. Cuando usas Spring Boot con webforJ, puedes inyectar servicios, repositorios y otros beans gestionados por Spring directamente en tus componentes de interfaz a través de la inyección por constructor.

Cuando utilizas Spring Boot con webforJ, tu aplicación se ejecuta como un JAR ejecutable con un servidor Tomcat embebido en lugar de desplegar un archivo WAR en un servidor de aplicaciones externo. Este modelo de empaquetado simplifica el despliegue y se alinea con las prácticas de despliegue nativas de la nube. El modelo de componentes y enrutamiento de webforJ funciona junto con el contexto de la aplicación de Spring para gestionar dependencias y configuración.

Crear una aplicación Spring Boot

Tienes dos opciones para crear una nueva aplicación webforJ con Spring Boot: utilizar la herramienta gráfica startforJ o la línea de comandos de Maven.

Opción 1: Usando startforJ

La forma más sencilla de crear una nueva aplicación webforJ es startforJ, que genera un proyecto inicial mínimo basado en un arquetipo webforJ elegido. Este proyecto inicial incluye todas las dependencias requeridas, archivos de configuración y un diseño pre-hecho, para que puedas comenzar a construir sobre él de inmediato.

Cuando creas una aplicación con startforJ, puedes personalizarla proporcionando la siguiente información:

  • Metadatos básicos del proyecto (Nombre de la aplicación, ID de grupo, ID de artefacto)
  • Versión de webforJ y versión de Java
  • Color y icono del tema
  • Arquetipo
  • Sabor - Selecciona webforJ Spring para crear un proyecto Spring Boot

Usando esta información, startforJ creará un proyecto básico de tu arquetipo elegido configurado para Spring Boot. Puedes optar por descargar tu proyecto como un archivo ZIP o publicarlo directamente en GitHub.

Opción 2: Usando la línea de comandos

Si prefieres usar la línea de comandos, genera un proyecto webforJ de Spring Boot directamente usando los arquetipos oficiales de webforJ:

mvn -B archetype:generate \
-DarchetypeGroupId=com.webforj \
-DarchetypeArtifactId=webforj-archetype-hello-world \
-DarchetypeVersion=LATEST \
-DgroupId=org.example \
-DartifactId=my-app \
-Dversion=1.0-SNAPSHOT \
-Dflavor=webforj-spring

El parámetro flavor indica al arquetipo que genere un proyecto Spring Boot en lugar de un proyecto estándar de webforJ.

Esto crea un proyecto completo de Spring Boot con:

  • Configuración del POM padre de Spring Boot
  • Dependencia de inicio de Spring Boot de webforJ
  • Clase principal de la aplicación con @SpringBootApplication y @Routify
  • Vistas de ejemplo
  • Archivos de configuración para Spring y webforJ

Agregar Spring Boot a proyectos existentes

Si tienes una aplicación webforJ existente, puedes agregar Spring Boot modificando la configuración de tu proyecto. Este proceso implica actualizar tu configuración de Maven, agregar dependencias de Spring y convertir tu clase principal de la aplicación.

Para proyectos existentes solamente

Salta esta sección si estás creando un nuevo proyecto desde cero. Esta guía asume versión 25.11 de webforJ o posterior.

Paso 1: Actualiza la configuración de Maven

Realiza los siguientes cambios en tu archivo POM:

  1. Cambia el empaquetado de WAR a JAR:

    pom.xml
    <packaging>jar</packaging>
  2. Establece Spring Boot como el POM padre:

    pom.xml
    <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>4.0.5</version>
    <relativePath/>
    </parent>
  3. Elimina cualquier configuración específica de WAR, como:

    • maven-war-plugin
    • Referencias al directorio webapp
    • Configuración relacionada con web.xml

Si ya tienes un POM padre, necesitarás importar el Bill of Materials (BOM) de Spring Boot en su lugar:

pom.xml
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>4.0.5</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>

Paso 2: Agregar dependencias de Spring

Agrega el iniciador de Spring Boot de webforJ a tus dependencias:

webforJ 25.11+ simplificación

A partir de la versión 25.11 de webforJ, el webforj-spring-boot-starter incluye todas las dependencias centrales de webforJ de forma transitiva. Ya no necesitas agregar explícitamente la dependencia com.webforj:webforj.

Para versiones anteriores a 25.11, debes incluir ambas dependencias por separado.

Para webforJ 25.11 y posteriores:

pom.xml
<dependencies>
<!-- Agregar iniciador de Spring Boot (incluye webforJ de forma transitiva) -->
<dependency>
<groupId>com.webforj</groupId>
<artifactId>webforj-spring-boot-starter</artifactId>
<version>${webforj.version}</version>
</dependency>

<!-- Agregar devtools -->
<dependency>
<groupId>com.webforj</groupId>
<artifactId>webforj-spring-devtools</artifactId>
<optional>true</optional>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>

Para versiones anteriores a 25.11:

pom.xml
<dependencies>
<!-- Agregar explícitamente la dependencia webforJ -->
<dependency>
<groupId>com.webforj</groupId>
<artifactId>webforj</artifactId>
<version>${webforj.version}</version>
</dependency>

<!-- Agregar iniciador de Spring Boot -->
<dependency>
<groupId>com.webforj</groupId>
<artifactId>webforj-spring-boot-starter</artifactId>
<version>${webforj.version}</version>
</dependency>

<!-- Agregar devtools -->
<dependency>
<groupId>com.webforj</groupId>
<artifactId>webforj-spring-devtools</artifactId>
<optional>true</optional>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
</dependencies>
DevTools de webforJ para actualización automática del navegador

La dependencia webforj-spring-devtools extiende Spring DevTools con actualización automática del navegador. Cuando guardas cambios en tu IDE, el navegador se recarga automáticamente sin intervención manual. Consulta la guía de Spring DevTools para detalles de configuración.

Paso 3: Actualizar plugins de construcción

Reemplaza el plugin de Jetty con el plugin de Maven de Spring Boot. Elimina cualquier configuración existente de Jetty y agrega:

pom.xml
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludeDevtools>true</excludeDevtools>
</configuration>
</plugin>
</plugins>
</build>

Paso 4: Convertir tu clase de aplicación

Transforma tu clase principal App en una aplicación de Spring Boot añadiendo las anotaciones de Spring necesarias y un método main:

Application.java
package com.example;

import com.webforj.App;
import com.webforj.annotation.Routify;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
@Routify(packages = "com.example.views")
public class Application extends App {

public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}

// Mantén tu método run() existente si tienes uno
@Override
public void run() throws WebforjException {
// Tu código de inicialización existente
}
}

La anotación @SpringBootApplication habilita la auto-configuración de Spring y el escaneo de componentes. La anotación @Routify permanece igual, continuando escaneando tus paquetes de vistas en busca de rutas.

Paso 5: Agregar configuración de Spring

Crea application.properties en src/main/resources:

application.properties
# Nombre de la clase completamente calificada del punto de entrada de la aplicación
webforj.entry = org.example.Application

# Nombre de la aplicación
spring.application.name=Hola Mundo Spring

# Configuración del servidor
server.port=8080
server.shutdown=immediate

# Configuración de DevTools de webforJ
spring.devtools.livereload.enabled=false
webforj.devtools.livereload.enabled=true
webforj.devtools.livereload.static-resources-enabled=true

Ejecutar la aplicación Spring Boot

Una vez configurada, ejecuta tu aplicación usando:

mvn spring-boot:run

La aplicación se inicia con un servidor Tomcat embebido en el puerto 8080 por defecto. Tus vistas y rutas de webforJ existentes funcionan exactamente como antes, pero ahora puedes inyectar beans de Spring y usar características de Spring.

Configuración

Utiliza el archivo application.properties en src/main/resources para configurar tu aplicación. Consulta Configuración de Propiedades para obtener información sobre las propiedades de configuración de webforJ.

Los siguientes ajustes de application.properties de webforJ son específicos de Spring:

PropiedadTipoDescripciónPredeterminado
webforj.servlet-mappingStringPatrón de mapeo de URL para el servlet de webforJ./*
webforj.exclude-urlsListPatrones de URL que no deberían ser manejados por webforJ cuando se mapean a la raíz. Cuando webforJ está mapeado al contexto raíz (/*), estos patrones de URL se excluirán del manejo de webforJ y pueden ser manejados por controladores de Spring MVC en su lugar. Esto permite que los endpoints REST y otros mapeos de Spring MVC coexistan con las rutas de webforJ.[]

Diferencias de configuración

Al cambiar a Spring Boot, varios aspectos de configuración cambian:

AspectowebforJ estándarwebforJ Spring Boot
EmpaquetadoArchivo WARJAR ejecutable
ServidorExterno (Jetty, Tomcat)Tomcat embebido
Comando de ejecuciónmvn jetty:runmvn spring-boot:run
Configuración principalSolo webforj.confapplication.properties + webforj.conf
Perfileswebforj-dev.conf, webforj-prod.confPerfiles de Spring con application-{profile}.properties
Configuración de puertoEn configuración del pluginserver.port en properties