Spring MVC - Esempio di Resolver della vista del pacchetto di risorse

Il ResourceBundleViewResolverviene utilizzato per risolvere i nomi delle viste utilizzando i bean di visualizzazione definiti nel file delle proprietà. L'esempio seguente mostra come utilizzare ResourceBundleViewResolver utilizzando Spring Web MVC Framework.

TestWeb-servlet.xml

<bean class = "org.springframework.web.servlet.view.ResourceBundleViewResolver">
   <property name = "basename" value = "views" />
</bean>

Qui, il basenamesi riferisce al nome del bundle di risorse, che contiene le viste. Il nome predefinito del bundle di risorse èviews.properties, che può essere sovrascritto utilizzando la proprietà basename.

views.properties

hello.(class) = org.springframework.web.servlet.view.JstlView
hello.url = /WEB-INF/jsp/hello.jsp

Ad esempio, utilizzando la configurazione precedente, se URI -

  • / hello è richiesto, DispatcherServlet inoltrerà la richiesta a hello.jsp definito da bean hello in views.properties.

  • Qui, "ciao" è il nome della vista da abbinare. Mentre,class si riferisce al tipo di vista e l'URL è la posizione della vista.

Per cominciare, disponiamo di un IDE Eclipse funzionante e prendiamo in considerazione i seguenti passaggi per sviluppare un'applicazione Web basata su modulo dinamico utilizzando Spring Web Framework.

Passo Descrizione
1 Crea un progetto con un nome TestWeb sotto un pacchetto com.tutorialspoint come spiegato nel capitolo Spring MVC - Hello World.
2 Crea una classe Java HelloController nel pacchetto com.tutorialspoint.
3 Crea un file di visualizzazione hello.jsp nella sottocartella jsp.
4 Crea un file delle proprietà views.properties nella cartella src.
5 Scarica la libreria JSTL jstl.jar . Mettilo nel tuo CLASSPATH.
6 Il passaggio finale è creare il contenuto dei file sorgente e di configurazione ed esportare l'applicazione come spiegato di seguito.

HelloController.java

package com.tutorialspoint;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.ui.ModelMap;

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

      return "hello";
   }

}

TestWeb-servlet.xml

<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.ResourceBundleViewResolver">
      <property name = "basename" value = "views" />
   </bean>
</beans>

views.properties

hello.(class) = org.springframework.web.servlet.view.JstlView
hello.url = /WEB-INF/jsp/hello.jsp

hello.jsp

<%@ page contentType="text/html; charset=UTF-8" %>
<html>
   <head>
      <title>Hello World</title>
   </head>
   <body>
      <h2>${message}</h2>
   </body>
</html>

Una volta terminata la creazione dei file sorgente e di configurazione, esporta l'applicazione. Fai clic destro sulla tua applicazione, usaExport → WAR File e salva il tuo file HelloWeb.war nella cartella webapps di Tomcat.

Ora avvia il tuo server Tomcat e assicurati di essere in grado di accedere ad altre pagine web dalla cartella webapps utilizzando un browser standard. Prova ad accedere all'URL -http://localhost:8080/HelloWeb/hello e se tutto va bene con l'applicazione Web Spring, vedremo la schermata seguente.