10.3 Spring

En este tema vamos a ver como poner en marcha una aplicación web que haga uso del framework Spring. Spring es un framework que al día de hoy es muy amplio y dispone de muchas funcionalidades. Nosotros en este curso solo vamos a ver la funcionalidad de:

Instalacion

Libreria de Spring

Descargar un fichero zip llamado spring-framework-4.x.y.RELEASE-dist.zip 1) de la siguiente página:

Los ejemplos de este curso han sido hechos con la versión 4.0.6 y el enlace directo es:

Una vez descargado hay que:

  • Crear una nueva carpeta llamada lib en la raiz del proyecto donde lo vayamos a utilizar Spring.
  • Descomprime el fichero spring-framework-4.0.6.RELEASE-dist.zip
  • Dentro de la carpeta que acabamos de descomprimir ir a la carpeta libs y copiar los siguientes jars en la nueva carpeta lib de nuestro proyecto:
    • spring-aop-4.0.6.RELEASE.jar
    • spring-beans-4.0.6.RELEASE.jar
    • spring-context-4.0.6.RELEASE.jar
    • spring-context-support-4.0.6.RELEASE.jar
    • spring-core-4.0.6.RELEASE.jar
    • spring-expression-4.0.6.RELEASE.jar
    • spring-web-4.0.6.RELEASE.jar
    • spring-webmvc-4.0.6.RELEASE.jar
  • Añadir los jars de la carpeta lib al proyecto usando rutas relativas.

Libreria de Apache Commons Loggin

Spring necesita de la librería Apache Commons Loggin, así que deberemos descargala y añadir también ciertos JARs a nuestros proyectos.

Descargar el fichero zip llamado commons-logging-1.x-bin.zip 2) de la siguiente página:

Los ejemplos de este curso han sido hechos con la versión 1.2 y el enlace directo es:

Una vez descargado hay que:

  • Descomprime el fichero commons-logging-1.2-bin.zip
  • Dentro de la carpeta ( o subcarpetas) que acabamos de descomprimir copiar los siguientes jars en la carpeta lib de nuestro proyecto:
    • commons-logging-1.2.jar
  • Añadir el jar de la carpeta lib al proyecto usando rutas relativas.

Configurando Spring

Una vez tenemos los jars que necesitamos para que funcione la aplicación en necesario configurar nuestra aplicación web para que funcione Spring. Para ello es necesario crear y configurar 3 ficheros:

web.xml

El fichero web.xml debe estar en la carpeta WEB-INF en las carpetas web. Es un fichero estándar de aplicaciones web en Java

Su contenido es el siguiente:

<?xml version="1.0" encoding="UTF-8"?>

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
         version="3.1">
    <session-config>
        <session-timeout>
            30
        </session-timeout>
    </session-config>
    
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener> 
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext.xml</param-value>
    </context-param>    

    <servlet>
        <servlet-name>dispatcher</servlet-name> 
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <load-on-startup>1</load-on-startup> 
    </servlet>
    <servlet-mapping>
        <servlet-name>dispatcher</servlet-name> 
        <url-pattern>/api/*</url-pattern>
    </servlet-mapping>
</web-app>

  • Línea 14: Indicamos que al iniciar la aplicación se ejecute la siguiente clase de Spring org.springframework.web.context.ContextLoaderListener. Esta clase es la que inicializará todo el framework.
  • Línea 18: Le indicamos que en el paquete raiz de Java classpath, se encuentra el fichero de configuración de Spring llamado applicationContext.xml.
  • Línea 23: Definimos un servlet desarrollado por Spring llamado org.springframework.web.servlet.DispatcherServlet. Este servlet será el encargado de procesar todas nuestras peticiones REST.
  • Línea 28: Le indicamos la URI que debe procesar el servlet de Spring y a partir de la cual estarán todas las URI de nuestros servicios REST, que es /api/*

Este fichero para cualquier proyecto lo podemos siempre pegar tal y como está ya que siguiendo nuestra arquitectura, la URI de nuestros servicios RST siempre empezará por /api y el fichero de configuración de Spring siempre lo llamamos applicationContext.xml y estará en el paquete raíz de las clases Java.

dispatcher-servlet.xml

El fichero dispatcher-servlet.xml debe estar en la carpeta WEB-INF en las carpetas web. El fichero dispatcher-servlet.xml es el fichero de configuración de la parte web de Spring, por lo tanto solo es necesario si estamos haciendo una aplicación web.

Su contenido es el siguiente:

<?xml version="1.0" encoding="UTF-8"?> 
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context" 
       xmlns:mvc="http://www.springframework.org/schema/mvc" 
       xsi:schemaLocation="
       http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
       http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd 
">

    <context:component-scan base-package="NOMBRE_DEL_PAQUETE_DE_LOS_CONTROLADORES_DE_SPRING" />
    
</beans>

  • Linea 12: Le debemos indicar el paquete Java donde se encuentran los controladores web que usaremos. Además permite que usemos anotaciones de Spring en nuestros controladores.

Recuerda modificar la línea <context:component-scan base-package=“NOMBRE_DEL_PAQUETE_DE_LOS_CONTROLADORES_DE_SPRING” /> para poner el nombre del paquete Java donde se encuentran los controladores web de tu aplicación.

applicationContext.xml

El fichero applicationContext.xml se encuentra en la carpeta raíz de las clases Java. Su nombre y su ubicación la hemos definido en el fichero web.xml aunque lo normal es que en todos los proyectos se llame así y esté en esa carpeta.

Su utilidad es configurar Spring en toda la parte que no tiene nada que ver con la web. Lo normal es poner aquí las clases que queremos que se puedan inyectar desde Spring. Lo podemos ver como nuestro configurador de inyección de dependencias. Aqui podremos las FQCN 3) de las clases que queremos que se puedan inyectar.

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="
       http://www.springframework.org/schema/beans   http://www.springframework.org/schema/beans/spring-beans-4.0.xsd
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
">
 
    <context:annotation-config/>
 
    <bean class="FQCN_DE_UNA_CLASE_JAVA_QUE_QUEREMOS_PODER_INYECTAR" />


</beans>

  • Linea 10: Permite que usemos anotaciones de Spring en nuestras clases Java como por ejemplo @Autowired
  • Línea 12: Esta línea indica que tenemos una clase Java que podrá ser inyectada por Spring.Hay que poner en el atributo class la FQCN 4) de la clase Java. Esta línea se puede repetir tantas veces como queramos para cada una de las clases que queramos que se puedan inyectar. O borrarla si no hay ninguna.

Recuerda borrar la línea <bean class=“FQCN_DE_UNA_CLASE_JAVA_QUE_QUEREMOS_PODER_INYECTAR” /> si no hay nada que inyectar o repetirla tantas veces como clases tengas para ser inyectadas por Spring.

Ejemplo

El ejemplo consiste en crear un sencillo controlador para probar que está bien configurado Spring.

Para crear el ejemplo deberemos hacer primeramente lo siguiente:

  • Desde NetBeans crear un nuevo projecto Web
  • Añadir las librerías de Spring
  • Añadir las librerías de Apache Commons Loggin
  • Añadir el fichero web.xml
  • Añadir el fichero dispatcher-servlet.xml
  • Añadir el fichero applicationContext.xml

Una vez hecho esto vamos a crear una clase Java llamada UsuarioController que actuará como controlador web. La clase debe estar en el paquete es.cursohibernate.spring.controller.

Su código es el siguiente:

package es.cursohibernate.spring.controller;

import java.io.IOException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;


@Controller
public class UsuarioController {
    
    
    @RequestMapping(value = {"/Usuario"})
    public void prueba(HttpServletRequest httpRequest, HttpServletResponse httpServletResponse) throws IOException {
        httpServletResponse.getWriter().println("Hola Mundo");
    }
}

Y por ahora no voy a explicar casi nada de esta clase ya que en siguientes temas hablaremos de los controladores y el objeto de este ejemplo es ver si Spring estaba bien configurado.

Una vez tenemos ésto hay que personalizar los ficheros dispatcher-servlet.xml y applicationContext.xml para ello deberemos:

  • Modificar el fichero dispatcher-servlet.xml para indicar que el paquete de los controladores es es.cursohibernate.spring.controller
  • Modificar el fichero applicationContext.xml y eliminar todas las líneas con <bean class=“FQCN_DE_UNA_CLASE_JAVA_QUE_QUEREMOS_PODER_INYECTAR” /> ya que no hay ninguna clase a inyectar.

Ahora ya podemos ejecutar la aplicación. Aparecerá el siguiente mensaje en la pantalla “TODO write content” . Esto significa que la aplicación ha arrancado , pero lo importan es navegar a http://localhost:8084/spring/api/Usuario y ver que aparece el texto “Hola Mundo”.

Si has visto el texto “Hola Mundo”, ¡Felicidades! Ya has conseguido hacer tu primera aplicación con Spring.

Referencias

1) Siendo x y y la versión a descargar
2) Siendo x la versión a descargar
3) , 4) Fully-Qualified Class Name. Es decir el nombre completo de una clase Java incluyendo el paquete al que pertenece.
unidades/10_servidor/03_spring.txt · Última modificación: 2014/08/31 00:43 por admin
Ir hasta arriba
CC Attribution-Share Alike 3.0 Unported
chimeric.de = chi`s home Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0