Spring - Descripción general del marco MVC

El marco Spring Web MVC proporciona una arquitectura de controlador de vista de modelo y componentes listos que se pueden usar para desarrollar aplicaciones web flexibles y poco acopladas. El patrón MVC da como resultado la separación de los diferentes aspectos de la aplicación (lógica de entrada, lógica empresarial y lógica de la interfaz de usuario), al tiempo que proporciona un acoplamiento flexible entre estos elementos.

  • los Model encapsula los datos de la aplicación y, en general, estarán compuestos por POJO.

  • los View es responsable de renderizar los datos del modelo y, en general, genera HTML salida que el navegador del cliente puede interpretar.

  • los Controller es responsable del procesamiento User Requests y Building Appropriate Model y lo pasa a la vista para renderizarlo.

El DispatcherServlet

El marco de Spring Web model-view-controller (MVC) está diseñado alrededor de un DispatcherServlet que maneja todas las solicitudes y respuestas HTTP. El flujo de trabajo de procesamiento de solicitudes de Spring Web MVC DispatcherServlet se muestra en la siguiente ilustración.

A continuación se muestra la secuencia de eventos correspondientes a una solicitud HTTP entrante a DispatcherServlet:

  • Después de recibir una solicitud HTTP, DispatcherServlet consulta el HandlerMapping para llamar al controlador apropiado.

  • El controlador toma la solicitud y llama a los métodos de servicio apropiados según los GET o POST method. El método de servicio establecerá los datos del modelo según la lógica empresarial definida y devuelve el nombre de la vista al DispatcherServlet.

  • DispatcherServlet recibirá ayuda de ViewResolver para recoger la vista definida para la solicitud.

  • Una vez finalizada la vista, DispatcherServlet pasa los datos del modelo a la vista, que finalmente se procesa, en los navegadores.

Todos los componentes mencionados anteriormente, es decir, HandlerMapping, Controller y ViewResolver son parte de WebApplicationContext, que es una extensión de la llanura ApplicationContext con algunas funciones adicionales necesarias para las aplicaciones web.

Configuración requerida

Necesitamos mapear las solicitudes que desea que el DispatcherServlet maneje, usando una asignación de URL en el web.xmlarchivo. El siguiente es un ejemplo para mostrar declaración y mapeo paraHelloWeb DispatcherServlet -

<web-app id = "WebApp_ID" version = "2.4"
   xmlns = "http://java.sun.com/xml/ns/j2ee" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://java.sun.com/xml/ns/j2ee 
   http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
 
   <display-name>Spring MVC Application</display-name>

   <servlet>
      <servlet-name>HelloWeb</servlet-name>
      <servlet-class>
         org.springframework.web.servlet.DispatcherServlet
      </servlet-class>
      <load-on-startup>1</load-on-startup>
   </servlet>

   <servlet-mapping>
      <servlet-name>HelloWeb</servlet-name>
      <url-pattern>*.jsp</url-pattern>
   </servlet-mapping>
</web-app>

los web.xml El archivo se mantendrá en el WebContent/WEB-INFdirectorio de su aplicación web. Tras la inicialización delHelloWeb DispatcherServlet, el marco intentará cargar el contexto de la aplicación desde un archivo llamado [servlet-name]-servlet.xmlubicado en el directorio WebContent / WEB-INF de la aplicación. En este caso, nuestro archivo seráHelloWeb-servlet.xml.

A continuación, el <servlet-mapping>La etiqueta indica qué URL gestionará qué DispatcherServlet. Aquí, todas las solicitudes HTTP que terminan en .jsp serán manejadas por elHelloWeb DispatcherServlet.

Si no desea utilizar el nombre de archivo predeterminado como [servlet-name]-servlet.xml y la ubicación predeterminada como WebContent / WEB-INF, puede personalizar este nombre de archivo y ubicación agregando el escucha de servlet ContextLoaderListener en su archivo web.xml de la siguiente manera:

<web-app...>

   <!-------- DispatcherServlet definition goes here----->
   ....
   <context-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>/WEB-INF/HelloWeb-servlet.xml</param-value>
   </context-param>

   <listener>
      <listener-class>
         org.springframework.web.context.ContextLoaderListener
      </listener-class>
   </listener>
</web-app>

Ahora, verifiquemos la configuración requerida para HelloWeb-servlet.xml archivo, ubicado en el directorio WebContent / WEB-INF de su aplicación web.

<beans xmlns = "http://www.springframework.org/schema/beans"
   xmlns:context = "http://www.springframework.org/schema/context"
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "
   http://www.springframework.org/schema/beans     
   http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
   http://www.springframework.org/schema/context 
   http://www.springframework.org/schema/context/spring-context-3.0.xsd">

   <context:component-scan base-package = "com.tutorialspoint" />

   <bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
      <property name = "prefix" value = "/WEB-INF/jsp/" />
      <property name = "suffix" value = ".jsp" />
   </bean>

</beans>

A continuación se presentan algunos puntos importantes sobre HelloWeb-servlet.xml archivo -

  • los [servlet-name]-servlet.xml El archivo se utilizará para crear los beans definidos, anulando las definiciones de los beans definidos con el mismo nombre en el ámbito global.

  • los <context:component-scan...> se usará para activar la capacidad de escaneo de anotaciones Spring MVC, que permite hacer uso de anotaciones como @Controller y @RequestMappingetc.

  • los InternalResourceViewResolvertendrá reglas definidas para resolver los nombres de las vistas. Según la regla definida anteriormente, una vista lógica denominadahello se delega en una implementación de vista ubicada en /WEB-INF/jsp/hello.jsp.

Entendamos ahora cómo crear los componentes reales, es decir, controlador, modelo y vista.

Definición de un controlador

DispatcherServlet delega la solicitud a los controladores para ejecutar la funcionalidad específica para él. los@ControllerLa anotación indica que una clase en particular cumple la función de controlador. los@RequestMapping La anotación se usa para asignar una URL a una clase completa o un método de manejo en particular.

@Controller
@RequestMapping("/hello")
public class HelloController{
 
   @RequestMapping(method = RequestMethod.GET)
   public String printHello(ModelMap model) {
      model.addAttribute("message", "Hello Spring MVC Framework!");
      return "hello";
   }

}

los @ControllerLa anotación define la clase como un controlador Spring MVC. Aquí, el primer uso de@RequestMapping indica que todos los métodos de manejo en este controlador son relativos al /hello camino.

La siguiente anotación @RequestMapping (method = RequestMethod.GET) se utiliza para declarar el printHello()como método de servicio predeterminado del controlador para manejar la solicitud HTTP GET. Podemos definir otro método para manejar cualquier solicitud POST en la misma URL.

También podemos escribir el controlador anterior en otra forma, donde podemos agregar atributos adicionales en @RequestMapping de la siguiente manera:

@Controller
public class HelloController{
 
   @RequestMapping(value = "/hello", method = RequestMethod.GET)
   public String printHello(ModelMap model) {
      model.addAttribute("message", "Hello Spring MVC Framework!");
      return "hello";
   }

}

los value El atributo indica la URL a la que se asigna el método del controlador y el method El atributo define el método de servicio para manejar la solicitud HTTP GET.

A continuación se presentan algunos puntos importantes a tener en cuenta con respecto al controlador definido anteriormente:

  • Definirá la lógica empresarial requerida dentro de un método de servicio. Puede llamar a otro método dentro de este método según el requisito.

  • Según la lógica empresarial definida, creará un modelo dentro de este método. Puede establecer diferentes atributos del modelo y la vista accederá a estos atributos para presentar el resultado. Este ejemplo crea un modelo con su atributo "mensaje".

  • Un método de servicio definido puede devolver una cadena, que contiene el nombre del viewque se utilizará para renderizar el modelo. Este ejemplo devuelve "hola" como nombre de vista lógica.

Creación de vistas JSP

Spring MVC admite muchos tipos de vistas para diferentes tecnologías de presentación. Éstas incluyen -JSPs, HTML, PDF, Excel Worksheets, XML, Velocity Templates, XSLT, JSON, Atom y RSS alimenta, JasperReports, etc. Sin embargo, las más comunes son las plantillas JSP escritas con JSTL. Entonces, escribamos una vista de saludo simple en /WEB-INF/hello/hello.jsp -

<html>
   <head>
      <title>Hello Spring MVC</title>
   </head>
   <body>
      <h2>${message}</h2>
   </body>
</html>

aquí ${message}Aquí está el atributo, que hemos configurado dentro del controlador. Puede tener varios atributos para que se muestren dentro de su vista.