Spring MVC - Guía rápida
El marco Spring Web MVC proporciona una arquitectura modelo-vista-controlador 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, constarán de 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 de procesar 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 en función de la lógica empresarial definida y devolverá el nombre de la vista al DispatcherServlet.
DispatcherServlet recibirá ayuda de ViewResolver para recoger la vista definida para la solicitud.
Una vez que se finaliza la vista, DispatcherServlet pasa los datos del modelo a la vista, que finalmente se representa 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, utilizando 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 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 utilizará 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 que deben tenerse 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.
Crear 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.
Este capítulo nos guiará sobre cómo preparar un entorno de desarrollo para comenzar a trabajar con Spring Framework. Este capítulo también nos enseñará cómo configurarJDK, Tomcat y Eclipse en su máquina antes de configurar Spring Framework -
Paso 1: configuración del kit de desarrollo de Java (JDK)
Puede descargar la última versión del sitio Java de Oracle - Descargas de Java SE . Encontrará instrucciones para instalar JDK en archivos descargados, siga las instrucciones dadas para instalar y configurar la instalación. Una vez que haya terminado con la configuración, configure las variables de entorno PATH y JAVA_HOME para hacer referencia al directorio que contienejava y javac, típicamente java_install_dir/bin y java_install_dir respectivamente.
Si está ejecutando Windows e instaló el JDK en C:\jdk1.6.0_15, tendría que poner la siguiente línea en su C:\autoexec.bat file.
set PATH = C:\jdk1.6.0_15\bin;%PATH%
set JAVA_HOME = C:\jdk1.6.0_15
Alternativamente, en Windows NT / 2000 / XP, también puede hacer clic con el botón derecho en Mi PC → seleccionar Propiedades → Avanzado → Variables de entorno. Luego, actualizaría el valor PATH y haría clic en el botón Aceptar.
En UNIX (Solaris, Linux, etc.), si el SDK está instalado en /usr/local/jdk1.6.0_15 y usa el shell C, entonces debe ingresar el siguiente comando en su .cshrc archivo.
setenv PATH /usr/local/jdk1.6.0_15/bin:$PATH
setenv JAVA_HOME /usr/local/jdk1.6.0_15
Alternativamente, si usa un entorno de desarrollo integrado (IDE) como Borland JBuilder, Eclipse, IntelliJ IDEA o Sun ONE Studio, luego compile y ejecute un programa simple para confirmar que el IDE sabe dónde está instalado Java; de lo contrario, realice la configuración adecuada como se indica en los documentos del IDE.
Paso 2: instalar la API de registro común de Apache
Puede descargar la última versión de Apache Commons Logging API desde https://commons.apache.org/logging/. Una vez que haya descargado la instalación, descomprima la distribución binaria en una ubicación conveniente.
Por ejemplo, C: \ commons-logging-1.1.1 en Windows o /usr/local/commons-logging1.1.1 en Linux / Unix. Este directorio tendrá los siguientes archivos jar y otros documentos de respaldo, etc.
Asegúrese de configurar su variable CLASSPATH en este directorio correctamente, de lo contrario tendrá problemas al ejecutar su aplicación.
Paso 3: configurar el IDE de Eclipse
Todos los ejemplos de este tutorial se han escrito utilizando el IDE de Eclipse. Por lo tanto, se recomienda que tengamos instalada la última versión de Eclipse en la máquina.
Para instalar Eclipse IDE, descargue los últimos binarios de Eclipse desde el siguiente enlace https://www.eclipse.org/downloads/. Una vez descargada la instalación, descomprima la distribución binaria en una ubicación conveniente.
Por ejemplo, en - C: \ eclipse en Windows, o / usr / local / eclipse en Linux / Unix y finalmente establezca la variable PATH de manera apropiada.
Eclipse se puede iniciar ejecutando los siguientes comandos en una máquina con Windows, o simplemente podemos hacer doble clic en eclipse.exe.
%C:\eclipse\eclipse.exe
Eclipse se puede iniciar ejecutando los siguientes comandos en una máquina UNIX (Solaris, Linux, etc.):
$/usr/local/eclipse/eclipse
Después de un inicio exitoso, si todo está bien, entonces debería mostrar la siguiente pantalla.
Paso 4: configurar las bibliotecas Spring Framework
Ahora, si todo está bien, podemos proceder a configurar Spring Framework. Los siguientes son los pasos para descargar e instalar el marco en la máquina.
Elija si desea instalar Spring en Windows o UNIX y luego continúe con el siguiente paso para descargar .zip file para ventanas y .tz archivo para Unix.
Descargue la última versión de los binarios de Spring Framework desde https://repo.spring.io/release/org/springframework/spring.
Hemos descargado el spring-framework-4.3.1.RELEASE-dist.zip en la máquina de Windows y cuando descomprimimos el archivo descargado, se mostrará la estructura del directorio dentro - E: \ spring de la siguiente manera.
Encontrarás todas las bibliotecas de Spring en el directorio E:\spring\libs. Asegúrese de configurar su variable CLASSPATH en este directorio correctamente; de lo contrario, enfrentaremos un problema al ejecutar la aplicación. Si usamos Eclipse, entonces no es necesario configurar CLASSPATH porque toda la configuración se realizará a través de Eclipse.
Una vez que haya terminado con este último paso, estará listo para continuar con su primer Ejemplo de primavera, que verá en el siguiente capítulo.
El siguiente ejemplo muestra cómo escribir un sencillo basado en web. Hello Worldaplicación utilizando Spring MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los pasos siguientes para desarrollar una aplicación web dinámica utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto web dinámico con un nombre HelloWeb y cree un paquete com.tutorialspoint en la carpeta src en el proyecto creado. |
2 | Arrastre y suelte la siguiente Spring y otras bibliotecas en la carpeta WebContent/WEB-INF/lib.. |
3 | Crea una clase de Java HelloController en el paquete com.tutorialspoint. |
4 | Crear configuración de Spring files web.xml y HelloWeb-servlet.xml en la carpeta WebContent / WEB-INF. |
5 | Crea una subcarpeta con un nombre jspen la carpeta WebContent / WEB-INF. Crear un archivo de vistahello.jsp en esta subcarpeta. |
6 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
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";
}
}
web.xml
<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>/</url-pattern>
</servlet-mapping>
</web-app>
HelloWeb-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.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
</beans>
hello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
A continuación se muestra la lista de Spring y otras bibliotecas que se incluirán en la aplicación web. Podemos simplemente arrastrar estos archivos y soltarlos en:WebContent/WEB-INF/lib carpeta.
servlet-api-x.y.z.jar
commons-logging-x.y.z.jar
spring-aop-x.y.z.jar
spring-beans-x.y.z.jar
spring-context-x.y.z.jar
spring-core-x.y.z.jar
spring-expression-x.y.z.jar
spring-webmvc-x.y.z.jar
spring-web-x.y.z.jar
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarda tu HelloWeb.war archivo en Tomcat's webapps carpeta.
Ahora inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Ahora, intente acceder a la URL:http://localhost:8080/HelloWeb/hello. Si todo está bien con la aplicación web Spring, veremos la siguiente pantalla.
Debe tener en cuenta que en la URL proporcionada, HelloWebes el nombre de la aplicación y hola es la subcarpeta virtual, que hemos mencionado en nuestro controlador usando @RequestMapping ("/ hola"). Puede usar la raíz directa mientras asigna su URL usando@RequestMapping("/"), en este caso puede acceder a la misma página utilizando una URL corta http://localhost:8080/HelloWeb/, pero se recomienda tener diferentes funcionalidades en diferentes carpetas.
El siguiente ejemplo muestra cómo escribir un sencillo basado en web. Hello Worldaplicación utilizando Spring MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los pasos siguientes para desarrollar una aplicación web dinámica utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases de Java Student, StudentController en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista student.jsp, result.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
Student.java
package com.tutorialspoint;
public class Student {
private Integer age;
private String name;
private Integer id;
public void setAge(Integer age) {
this.age = age;
}
public Integer getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
}
StudentController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class StudentController {
@RequestMapping(value = "/student", method = RequestMethod.GET)
public ModelAndView student() {
return new ModelAndView("student", "command", new Student());
}
@RequestMapping(value = "/addStudent", method = RequestMethod.POST)
public String addStudent(@ModelAttribute("SpringWeb")Student student,
ModelMap model) {
model.addAttribute("name", student.getName());
model.addAttribute("age", student.getAge());
model.addAttribute("id", student.getId());
return "result";
}
}
Aquí, el primer método de servicio student(), hemos pasado un Studentobject en blanco en el objeto ModelAndView con el nombre "comando". Esto se hace porque el marco Spring espera un objeto con el nombre "comando", si usamos etiquetas <form: form> en el archivo JSP. Entonces, cuando se llama al método student (), devuelve la vista student.jsp.
El segundo método de servicio addStudent()se llamará contra un método POST en la URL HelloWeb / addStudent. Preparará su objeto modelo en función de la información enviada. Finalmente, se devolverá una vista de "resultado" del método de servicio, que dará como resultado la representación de result.jsp.
student.jsp
<%@taglib uri="http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Student Information</h2>
<form:form method = "POST" action = "/HelloWeb/addStudent">
<table>
<tr>
<td><form:label path = "name">Name</form:label></td>
<td><form:input path = "name" /></td>
</tr>
<tr>
<td><form:label path = "age">Age</form:label></td>
<td><form:input path = "age" /></td>
</tr>
<tr>
<td><form:label path = "id">id</form:label></td>
<td><form:input path = "id" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
result.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted Student Information</h2>
<table>
<tr>
<td>Name</td>
<td>${name}</td>
</tr>
<tr>
<td>Age</td>
<td>${age}</td> </tr> <tr> <td>ID</td> <td>${id}</td>
</tr>
</table>
</body>
</html>
Una vez que hayamos terminado con la creación de archivos fuente y de configuración, exporte su aplicación. Haga clic con el botón derecho en su aplicación, use la opción Exportar → Archivo WAR y guarde elSpringWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Ahora, pruebe con una URL: http: // localhost: 8080 / SpringWeb / student y debería ver la siguiente pantalla si todo está bien con la aplicación Spring Web.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Debería ver la siguiente pantalla, si todo está bien con su aplicación web Spring.
El siguiente ejemplo muestra cómo escribir una aplicación sencilla basada en web, que hace uso de redireccionamiento para transferir una solicitud http a otra página. Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework:
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un WebController de clase Java en el paquete com.tutorialspoint. |
3 | Cree archivos de vista index.jsp, final.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
WebController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Controller
public class WebController {
@RequestMapping(value = "/index", method = RequestMethod.GET)
public String index() {
return "index";
}
@RequestMapping(value = "/redirect", method = RequestMethod.GET)
public String redirect() {
return "redirect:finalPage";
}
@RequestMapping(value = "/finalPage", method = RequestMethod.GET)
public String finalPage() {
return "final";
}
}
A continuación se muestra el contenido del archivo de vista Spring index.jsp. Esta será una página de destino, esta página enviará una solicitud al método de servicio de redireccionamiento de acceso, que redirigirá esta solicitud a otro método de servicio y finalmente a unfinal.jspse mostrará la página.
index.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring Page Redirection</title>
</head>
<body>
<h2>Spring Page Redirection</h2>
<p>Click below button to redirect the result to new page</p>
<form:form method = "GET" action = "/HelloWeb/redirect">
<table>
<tr>
<td>
<input type = "submit" value = "Redirect Page"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
final.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring Page Redirection</title>
</head>
<body>
<h2>Redirected Page</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, use la opción Exportar → Archivo WAR y guarde su archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Pruebe una URL –http: // localhost: 8080 / HelloWeb / index y debería ver la siguiente pantalla si todo está bien con la aplicación Spring Web.
Ahora haga clic en el botón "Redirigir página" para enviar el formulario y acceder a la página final redirigida. Deberíamos ver la siguiente pantalla, si todo está bien con nuestra aplicación web Spring:
El siguiente ejemplo muestra cómo escribir una aplicación web simple usando Spring MVC Framework, que puede acceder a páginas estáticas junto con páginas dinámicas con la ayuda de un <mvc:resources> etiqueta.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un WebController de clase Java en el paquete com.tutorialspoint. |
3 | Crea un archivo estático final.htm en la subcarpeta jsp. |
4 | Actualice el archivo de configuración de Spring HelloWeb-servlet.xml en la carpeta WebContent / WEB-INF como se muestra a continuación. |
5 | El último paso es crear el contenido de los archivos fuente y de configuración y exportar la aplicación, que se explica a continuación. |
WebController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Controller
public class WebController {
@RequestMapping(value = "/index", method = RequestMethod.GET)
public String index() {
return "index";
}
@RequestMapping(value = "/staticPage", method = RequestMethod.GET)
public String redirect() {
return "redirect:/pages/final.htm";
}
}
HelloWeb-servlet.xml
<?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-2.5.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-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 id = "viewResolver" class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
<mvc:resources mapping = "/pages/**" location = "/WEB-INF/pages/" />
<mvc:annotation-driven/>
</beans>
Aquí el <mvc:resources..../>se está utilizando para mapear páginas estáticas. El atributo de mapeo debe ser unAnt patternque especifica el patrón de URL de una solicitud http. El atributo de ubicación debe especificar una o más ubicaciones de directorio de recursos válidas que tengan páginas estáticas, incluidas imágenes, hojas de estilo, JavaScript y otro contenido estático. Se pueden especificar varias ubicaciones de recursos mediante una lista de valores separados por comas.
A continuación se muestra el contenido del archivo de vista Spring WEB-INF/jsp/index.jsp. Esta será una página de destino; esta página enviará una solicitud para acceder alstaticPage service method, que redirigirá esta solicitud a una página estática disponible en la carpeta WEB-INF / pages.
index.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring Landing Page</title>
</head>
<body>
<h2>Spring Landing Pag</h2>
<p>Click below button to get a simple HTML page</p>
<form:form method = "GET" action = "/HelloWeb/staticPage">
<table>
<tr>
<td>
<input type = "submit" value = "Get HTML Page"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
final.htm
<html>
<head>
<title>Spring Static Page</title>
</head>
<body>
<h2>A simple HTML page</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, use la opción Exportar → Archivo WAR y guarde su archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Ahora intente acceder a la URL: http: // localhost: 8080 / HelloWeb / index. Si todo está bien con la aplicación web Spring, veremos la siguiente pantalla.
Haga clic en el botón "Obtener página HTML" para acceder a una página estática mencionada en el método de servicio staticPage. Si todo está bien con su aplicación web Spring, veremos la siguiente pantalla.
El siguiente ejemplo muestra cómo usar cuadros de texto en formularios usando el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework:
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World Example. |
2 | Cree un Student de clases de Java, StudentController en el paquete com.tutorialspoint. |
3 | Cree una vista de archivos student.jsp, result.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
Student.java
package com.tutorialspoint;
public class Student {
private Integer age;
private String name;
private Integer id;
public void setAge(Integer age) {
this.age = age;
}
public Integer getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
}
StudentController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class StudentController {
@RequestMapping(value = "/student", method = RequestMethod.GET)
public ModelAndView student() {
return new ModelAndView("student", "command", new Student());
}
@RequestMapping(value = "/addStudent", method = RequestMethod.POST)
public String addStudent(@ModelAttribute("SpringWeb")Student student,
ModelMap model) {
model.addAttribute("name", student.getName());
model.addAttribute("age", student.getAge());
model.addAttribute("id", student.getId());
return "result";
}
}
Aquí, el primer método de servicio student(), hemos pasado un Studentobject en blanco en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando <form:form>etiquetas en su archivo JSP. Entonces, cuando se llama al método student (), devuelvestudent.jsp view.
El segundo método de servicio addStudent() se llamará contra un método POST en el HelloWeb/addStudentURL. Preparará su objeto modelo en función de la información enviada. Finalmente, se devolverá una vista de "resultado" del método de servicio, lo que dará como resultado la representación de result.jsp
student.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Student Information</h2>
<form:form method = "POST" action = "/HelloWeb/addStudent">
<table>
<tr>
<td><form:label path = "name">Name</form:label></td>
<td><form:input path = "name" /></td>
</tr>
<tr>
<td><form:label path = "age">Age</form:label></td>
<td><form:input path = "age" /></td>
</tr>
<tr>
<td><form:label path = "id">id</form:label></td>
<td><form:input path = "id" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando <form:input />etiqueta para representar un cuadro de texto HTML. Por ejemplo
<form:input path = "name" />
Representará el siguiente contenido HTML.
<input id = "name" name = "name" type = "text" value = ""/>
result.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted Student Information</h2>
<table>
<tr>
<td>Name</td>
<td>${name}</td> </tr> <tr> <td>Age</td> <td>${age}</td>
</tr>
<tr>
<td>ID</td>
<td>${id}</td>
</tr>
</table>
</body>
</html>
Una vez que hayamos terminado con la creación de archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/HelloWeb/student y veremos la siguiente pantalla si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Deberíamos ver la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo describe cómo usar la contraseña en formularios que utilizan el marco Spring Web MVC. Para empezar, tengamos un Eclipse IDE en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree los archivos de visualización user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
}
UserController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
return new ModelAndView("user", "command", new User());
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
return "users";
}
}
Aquí, el primer método de servicio user(), hemos pasado un objeto User en blanco en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Entonces, cuando se llama al método user (), devuelve la vista user.jsp.
El segundo método de servicio addUser()se llamará contra un método POST en la URL HelloWeb / addUser. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp.
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando la etiqueta <formulario: contraseña /> para representar un cuadro de contraseña HTML. Por ejemplo
<form:password path = "password" />
Representará el siguiente contenido HTML.
<input id = "password" name = "password" type = "password" value = ""/>
users.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td>
</tr>
<tr>
<td>Password</td>
<td>${password}</td>
</tr>
</table>
</body>
</html>
Una vez que hayamos terminado con la creación de archivos fuente y de configuración, exporte la aplicación. Haga clic derecho en su aplicación, use la opción Exportar → Archivo WAR y guarde su archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Pruebe una URL –http: // localhost: 8080 / HelloWeb / user y veremos la siguiente pantalla si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo explica cómo usar TextArea en formularios usando el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los pasos siguientes para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree los archivos de visualización user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
private String address;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
UserController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
return new ModelAndView("user", "command", new User());
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
model.addAttribute("address", user.getAddress());
return "users";
}
}
Aquí, para el primer método de servicio user (), hemos pasado un objeto User en blanco en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando <formulario: formulario> etiquetas en su archivo JSP. Entonces, cuando se llama al método user (), devuelve la vista user.jsp.
El segundo método de servicio addUser () se llamará contra un método POST en la URL de HelloWeb / addUser. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp.
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td><form:label path = "address">Address</form:label></td>
<td><form:textarea path = "address" rows = "5" cols = "30" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando <form:textarea />etiqueta para representar un cuadro de área de texto HTML. Por ejemplo
<form:textarea path = "address" rows = "5" cols = "30" />
Representará el siguiente contenido HTML.
<textarea id = "address" name = "address" rows = "5" cols = "30"></textarea>
users.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td>
</tr>
<tr>
<td>Password</td>
<td>${password}</td> </tr> <tr> <td>Address</td> <td>${address}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, use la opción Exportar → Archivo WAR y guarde su archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Pruebe una URL –http: // localhost: 8080 / HelloWeb / user y veremos la siguiente pantalla si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo describe cómo usar una casilla de verificación única en formularios que utilizan el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspointas explicado en el capítulo Spring MVC - Hello World Example. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree una vista de archivos user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
private String address;
private boolean receivePaper;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public boolean isReceivePaper() {
return receivePaper;
}
public void setReceivePaper(boolean receivePaper) {
this.receivePaper = receivePaper;
}
}
UserController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
return new ModelAndView("user", "command", new User());
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
model.addAttribute("address", user.getAddress());
model.addAttribute("receivePaper", user.isReceivePaper());
return "users";
}
}
Aquí, para el primer método de servicio user (), hemos pasado un objeto User en blanco en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando <formulario: formulario> etiquetas en su archivo JSP. Entonces, cuando se llama al método user (), devuelve la vista user.jsp.
El segundo método de servicio addUser () se llamará contra un método POST en la URL de HelloWeb / addUser. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp.
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td><form:label path = "address">Address</form:label></td>
<td><form:textarea path = "address" rows = "5" cols = "30" /></td>
</tr>
<tr>
<td><form:label path = "receivePaper">Subscribe Newsletter</form:label></td>
<td><form:checkbox path = "receivePaper" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando <form:checkboxes /> etiqueta para representar una casilla de verificación HTML.
Por ejemplo
<form:checkbox path="receivePaper" />
Representará el siguiente contenido HTML.
<input id="receivePaper1" name = "receivePaper" type = "checkbox" value = "true"/>
<input type = "hidden" name = "_receivePaper" value = "on"/>
users.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td> </tr> <tr> <td>Password</td> <td>${password}</td>
</tr>
<tr>
<td>Address</td>
<td>${address}</td> </tr> <tr> <td>Subscribed to Newsletter</td> <td>${receivePaper}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, use la opción Exportar → Archivo WAR y guarde su archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Pruebe una URL: http: // localhost: 8080 / HelloWeb / user y veremos la siguiente pantalla si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Veremos la siguiente pantalla si todo está bien con la aplicación web Spring.
El siguiente ejemplo explica cómo usar varias casillas de verificación en formularios que utilizan el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
private String address;
private boolean receivePaper;
private String [] favoriteFrameworks;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public boolean isReceivePaper() {
return receivePaper;
}
public void setReceivePaper(boolean receivePaper) {
this.receivePaper = receivePaper;
}
public String[] getFavoriteFrameworks() {
return favoriteFrameworks;
}
public void setFavoriteFrameworks(String[] favoriteFrameworks) {
this.favoriteFrameworks = favoriteFrameworks;
}
}
UserController.java
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.List;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
User user = new User();
user.setFavoriteFrameworks((new String []{"Spring MVC","Struts 2"}));
ModelAndView modelAndView = new ModelAndView("user", "command", user);
return modelAndView;
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
model.addAttribute("address", user.getAddress());
model.addAttribute("receivePaper", user.isReceivePaper());
model.addAttribute("favoriteFrameworks", user.getFavoriteFrameworks());
return "users";
}
@ModelAttribute("webFrameworkList")
public List<String> getWebFrameworkList() {
List<String> webFrameworkList = new ArrayList<String>();
webFrameworkList.add("Spring MVC");
webFrameworkList.add("Struts 1");
webFrameworkList.add("Struts 2");
webFrameworkList.add("Apache Wicket");
return webFrameworkList;
}
}
Aquí, para el primer método de servicio user(), hemos pasado un espacio en blanco Userobjeto en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Entonces, cuando eluser() se llama al método, devuelve el user.jsp ver.
El segundo método de servicio addUser() se llamará contra un método POST en el HelloWeb/addUserURL. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td><form:label path = "address">Address</form:label></td>
<td><form:textarea path = "address" rows = "5" cols = "30" /></td>
</tr>
<tr>
<td><form:label path = "receivePaper">Subscribe Newsletter</form:label></td>
<td><form:checkbox path = "receivePaper" /></td>
</tr>
<tr>
<td><form:label path = "favoriteFrameworks">Favorite Web Frameworks</form:label></td>
<td><form:checkboxes items = "${webFrameworkList}" path = "favoriteFrameworks" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando <form:checkboxes /> etiqueta para representar casillas de verificación HTML.
<form:checkboxes items = "${webFrameworkList}" path = "favoriteFrameworks" />
Representará el siguiente contenido HTML.
<span>
<input id = "favoriteFrameworks1" name = "favoriteFrameworks" type = "checkbox" value = "Spring MVC" checked = "checked"/>
<label for = "favoriteFrameworks1">Spring MVC</label>
</span>
<span>
<input id = "favoriteFrameworks2" name = "favoriteFrameworks" type = "checkbox" value = "Struts 1"/>
<label for = "favoriteFrameworks2">Struts 1</label>
</span>
<span>
<input id = "favoriteFrameworks3" name = "favoriteFrameworks" type = "checkbox" value = "Struts 2" checked = "checked"/>
<label for = "favoriteFrameworks3">Struts 2</label>
</span>
<span>
<input id = "favoriteFrameworks4" name = "favoriteFrameworks" type = "checkbox" value = "Apache Wicket"/>
<label for = "favoriteFrameworks4">Apache Wicket</label>
</span>
<input type = "hidden" name = "_favoriteFrameworks" value = "on"/>
users.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td> </tr> <tr> <td>Password</td> <td>${password}</td>
</tr>
<tr>
<td>Address</td>
<td>${address}</td> </tr> <tr> <td>Subscribed to Newsletter</td> <td>${receivePaper}</td>
</tr>
<tr>
<td>Favorite Web Frameworks</td>
<td> <% String[] favoriteFrameworks = (String[])request.getAttribute("favoriteFrameworks");
for(String framework: favoriteFrameworks) {
out.println(framework);
}
%></td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarda tu HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Prueba una URLhttp://localhost:8080/HelloWeb/user y veremos la siguiente pantalla si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Veremos la siguiente pantalla, si todo está bien con su aplicación web Spring.
El siguiente ejemplo muestra cómo usar RadioButton en formularios usando el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework:
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
private String address;
private boolean receivePaper;
private String [] favoriteFrameworks;
private String gender;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public boolean isReceivePaper() {
return receivePaper;
}
public void setReceivePaper(boolean receivePaper) {
this.receivePaper = receivePaper;
}
public String[] getFavoriteFrameworks() {
return favoriteFrameworks;
}
public void setFavoriteFrameworks(String[] favoriteFrameworks) {
this.favoriteFrameworks = favoriteFrameworks;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
}
UserController.java
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.List;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
User user = new User();
user.setFavoriteFrameworks((new String []{"Spring MVC","Struts 2"}));
user.setGender("M");
ModelAndView modelAndView = new ModelAndView("user", "command", user);
return modelAndView;
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
model.addAttribute("address", user.getAddress());
model.addAttribute("receivePaper", user.isReceivePaper());
model.addAttribute("favoriteFrameworks", user.getFavoriteFrameworks());
model.addAttribute("gender", user.getGender());
return "users";
}
@ModelAttribute("webFrameworkList")
public List<String> getWebFrameworkList() {
List<String> webFrameworkList = new ArrayList<String>();
webFrameworkList.add("Spring MVC");
webFrameworkList.add("Struts 1");
webFrameworkList.add("Struts 2");
webFrameworkList.add("Apache Wicket");
return webFrameworkList;
}
}
Aquí, el primer método de servicio user(), hemos pasado un espacio en blanco Userobjeto en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Entonces, cuando eluser() se llama al método, devuelve el user.jsp ver.
El segundo método de servicio addUser() se llamará contra un método POST en el HelloWeb/addUserURL. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp.
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td><form:label path = "address">Address</form:label></td>
<td><form:textarea path = "address" rows = "5" cols = "30" /></td>
</tr>
<tr>
<td><form:label path = "receivePaper">Subscribe Newsletter</form:label></td>
<td><form:checkbox path = "receivePaper" /></td>
</tr>
<tr>
<td><form:label path = "favoriteFrameworks">Favorite Web Frameworks</form:label></td>
<td><form:checkboxes items = "${webFrameworkList}" path = "favoriteFrameworks" /></td>
</tr>
<tr>
<td><form:label path = "gender">Gender</form:label></td>
<td>
<form:radiobutton path = "gender" value = "M" label = "Male" />
<form:radiobutton path = "gender" value = "F" label = "Female" />
</td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando <form:radiobutton /> etiqueta para representar el botón de radio HTML.
<form:radiobutton path = "gender" value = "M" label = "Male" />
<form:radiobutton path = "gender" value = "F" label = "Female" />
Representará el siguiente contenido HTML.
<input id = "gender1" name = "gender" type = "radio" value = "M" checked = "checked"/><label for = "gender1">Male</label>
<input id = "gender2" name = "gender" type = "radio" value = "F"/><label for = "gender2">Female</label>
users.jsp
<%@taglib uri="http://www.springframework.org/tags/form" prefix="form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td>
</tr>
<tr>
<td>Password</td>
<td>${password}</td> </tr> <tr> <td>Address</td> <td>${address}</td>
</tr>
<tr>
<td>Subscribed to Newsletter</td>
<td>${receivePaper}</td> </tr> <tr> <td>Favorite Web Frameworks</td> <td> <% String[] favoriteFrameworks = (String[])request.getAttribute("favoriteFrameworks"); for(String framework: favoriteFrameworks) { out.println(framework); } %></td> </tr> <tr> <td>Gender</td> <td>${(gender=="M"? "Male" : "Female")}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Prueba una URL -http://localhost:8080/HelloWeb/user y veremos la siguiente pantalla, si todo está bien con su aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo explica cómo usar RadioButtons en formularios usando el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los pasos siguientes para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
private String address;
private boolean receivePaper;
private String [] favoriteFrameworks;
private String gender;
private String favoriteNumber;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public boolean isReceivePaper() {
return receivePaper;
}
public void setReceivePaper(boolean receivePaper) {
this.receivePaper = receivePaper;
}
public String[] getFavoriteFrameworks() {
return favoriteFrameworks;
}
public void setFavoriteFrameworks(String[] favoriteFrameworks) {
this.favoriteFrameworks = favoriteFrameworks;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public String getFavoriteNumber() {
return favoriteNumber;
}
public void setFavoriteNumber(String favoriteNumber) {
this.favoriteNumber = favoriteNumber;
}
}
UserController.java
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.List;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
User user = new User();
user.setFavoriteFrameworks((new String []{"Spring MVC","Struts 2"}));
user.setGender("M");
ModelAndView modelAndView = new ModelAndView("user", "command", user);
return modelAndView;
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
model.addAttribute("address", user.getAddress());
model.addAttribute("receivePaper", user.isReceivePaper());
model.addAttribute("favoriteFrameworks", user.getFavoriteFrameworks());
model.addAttribute("gender", user.getGender());
model.addAttribute("favoriteNumber", user.getFavoriteNumber());
return "users";
}
@ModelAttribute("webFrameworkList")
public List<String> getWebFrameworkList() {
List<String> webFrameworkList = new ArrayList<String>();
webFrameworkList.add("Spring MVC");
webFrameworkList.add("Struts 1");
webFrameworkList.add("Struts 2");
webFrameworkList.add("Apache Wicket");
return webFrameworkList;
}
@ModelAttribute("numbersList")
public List<String> getNumbersList() {
List<String> numbersList = new ArrayList<String>();
numbersList.add("1");
numbersList.add("2");
numbersList.add("3");
numbersList.add("4");
return numbersList;
}
}
Aquí, para el primer método de servicio user (), hemos pasado un objeto User en blanco en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando <formulario: formulario> etiquetas en su archivo JSP. Entonces, cuando se llama al método user (), devuelve la vista user.jsp.
El segundo método de servicio addUser() se llamará contra un método POST en el HelloWeb/addUserURL. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp.
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td><form:label path = "address">Address</form:label></td>
<td><form:textarea path = "address" rows = "5" cols = "30" /></td>
</tr>
<tr>
<td><form:label path = "receivePaper">Subscribe Newsletter</form:label></td>
<td><form:checkbox path = "receivePaper" /></td>
</tr>
<tr>
<td><form:label path = "favoriteFrameworks">Favorite Web Frameworks</form:label></td>
<td><form:checkboxes items = "${webFrameworkList}" path = "favoriteFrameworks" /></td> </tr> <tr> <td><form:label path = "gender">Gender</form:label></td> <td> <form:radiobutton path = "gender" value = "M" label = "Male" /> <form:radiobutton path = "gender" value = "F" label = "Female" /> </td> </tr> <tr> <td><form:label path = "favoriteNumber">Favorite Number</form:label></td> <td> <form:radiobuttons path = "favoriteNumber" items = "${numbersList}" />
</td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando <form:radiobuttons />etiqueta para representar los botones de radio HTML. Por ejemplo
<form:radiobuttons path = "favoriteNumber" items="${numbersList}" />
Representará el siguiente contenido HTML.
<span>
<input id = "favoriteNumber1" name = "favoriteNumber" type = "radio" value = "1"/>
<label for = "favoriteNumber1">1</label>
</span>
<span>
<input id = "favoriteNumber2" name = "favoriteNumber" type = "radio" value = "2"/>
<label for = "favoriteNumber2">2</label>
</span>
<span>
<input id = "favoriteNumber3" name = "favoriteNumber" type = "radio" value = "3"/>
<label for = "favoriteNumber3">3</label>
</span>
<span>
<input id = "favoriteNumber4" name = "favoriteNumber" type = "radio" value = "4"/>
<label for = "favoriteNumber4">4</label>
</span>
users.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td>
</tr>
<tr>
<td>Password</td>
<td>${password}</td> </tr> <tr> <td>Address</td> <td>${address}</td>
</tr>
<tr>
<td>Subscribed to Newsletter</td>
<td>${receivePaper}</td> </tr> <tr> <td>Favorite Web Frameworks</td> <td> <% String[] favoriteFrameworks = (String[])request.getAttribute("favoriteFrameworks"); for(String framework: favoriteFrameworks) { out.println(framework); } %></td> </tr> <tr> <td>Gender</td> <td>${(gender=="M"? "Male" : "Female")}</td>
</tr>
<tr>
<td>Favourite Number</td>
<td>${favoriteNumber}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File y guarde el archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba la siguiente URL:http://localhost:8080/HelloWeb/user y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Veremos la siguiente pantalla, si todo está bien con su aplicación web Spring.
El siguiente ejemplo describe cómo usar Dropdown en formularios usando el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
private String address;
private boolean receivePaper;
private String [] favoriteFrameworks;
private String gender;
private String favoriteNumber;
private String country;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public boolean isReceivePaper() {
return receivePaper;
}
public void setReceivePaper(boolean receivePaper) {
this.receivePaper = receivePaper;
}
public String[] getFavoriteFrameworks() {
return favoriteFrameworks;
}
public void setFavoriteFrameworks(String[] favoriteFrameworks) {
this.favoriteFrameworks = favoriteFrameworks;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public String getFavoriteNumber() {
return favoriteNumber;
}
public void setFavoriteNumber(String favoriteNumber) {
this.favoriteNumber = favoriteNumber;
}
public String getCountry() {
return country;
}
public void setCountry(String country) {
this.country = country;
}
}
UserController.java
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
User user = new User();
user.setFavoriteFrameworks((new String []{"Spring MVC","Struts 2"}));
user.setGender("M");
ModelAndView modelAndView = new ModelAndView("user", "command", user);
return modelAndView;
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
model.addAttribute("address", user.getAddress());
model.addAttribute("receivePaper", user.isReceivePaper());
model.addAttribute("favoriteFrameworks", user.getFavoriteFrameworks());
model.addAttribute("gender", user.getGender());
model.addAttribute("favoriteNumber", user.getFavoriteNumber());
model.addAttribute("country", user.getCountry());
return "users";
}
@ModelAttribute("webFrameworkList")
public List<String> getWebFrameworkList() {
List<String> webFrameworkList = new ArrayList<String>();
webFrameworkList.add("Spring MVC");
webFrameworkList.add("Struts 1");
webFrameworkList.add("Struts 2");
webFrameworkList.add("Apache Wicket");
return webFrameworkList;
}
@ModelAttribute("numbersList")
public List<String> getNumbersList() {
List<String> numbersList = new ArrayList<String>();
numbersList.add("1");
numbersList.add("2");
numbersList.add("3");
numbersList.add("4");
return numbersList;
}
@ModelAttribute("countryList")
public Map<String, String> getCountryList() {
Map<String, String> countryList = new HashMap<String, String>();
countryList.put("US", "United States");
countryList.put("CH", "China");
countryList.put("SG", "Singapore");
countryList.put("MY", "Malaysia");
return countryList;
}
}
Aquí, para el primer método de servicio user(), hemos pasado un espacio en blanco Userobjeto en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Entonces cuando eluser() se llama al método, devuelve el user.jsp ver.
El segundo método de servicio addUser() se llamará contra un método POST en el HelloWeb/addUserURL. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp.
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td><form:label path = "address">Address</form:label></td>
<td><form:textarea path = "address" rows = "5" cols = "30" /></td>
</tr>
<tr>
<td><form:label path = "receivePaper">Subscribe Newsletter</form:label></td>
<td><form:checkbox path = "receivePaper" /></td>
</tr>
<tr>
<td><form:label path = "favoriteFrameworks">Favorite Web Frameworks</form:label></td>
<td><form:checkboxes items = "${webFrameworkList}" path = "favoriteFrameworks" /></td>
</tr>
<tr>
<td><form:label path = "gender">Gender</form:label></td>
<td>
<form:radiobutton path = "gender" value = "M" label = "Male" />
<form:radiobutton path = "gender" value = "F" label = "Female" />
</td>
</tr>
<tr>
<td><form:label path = "favoriteNumber">Favorite Number</form:label></td>
<td>
<form:radiobuttons path = "favoriteNumber" items = "${numbersList}" /> </td> </tr> <tr> <td><form:label path = "country">Country</form:label></td> <td> <form:select path = "country"> <form:option value = "NONE" label = "Select"/> <form:options items = "${countryList}" />
</form:select>
</td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando <form:select /> , <form:option /> y <form:options />etiquetas para renderizar HTML select. Por ejemplo
<form:select path = "country">
<form:option value = "NONE" label = "Select"/>
<form:options items = "${countryList}" />
</form:select>
Representará el siguiente contenido HTML.
<select id = "country" name = "country">
<option value = "NONE">Select</option>
<option value = "US">United States</option>
<option value = "CH">China</option>
<option value = "MY">Malaysia</option>
<option value = "SG">Singapore</option>
</select>
users.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td>
</tr>
<tr>
<td>Password</td>
<td>${password}</td> </tr> <tr> <td>Address</td> <td>${address}</td>
</tr>
<tr>
<td>Subscribed to Newsletter</td>
<td>${receivePaper}</td> </tr> <tr> <td>Favorite Web Frameworks</td> <td> <% String[] favoriteFrameworks = (String[])request.getAttribute("favoriteFrameworks"); for(String framework: favoriteFrameworks) { out.println(framework); } %></td> </tr> <tr> <td>Gender</td> <td>${(gender=="M"? "Male" : "Female")}</td>
</tr>
<tr>
<td>Favourite Number</td>
<td>${favoriteNumber}</td> </tr> <tr> <td>Country</td> <td>${country}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, use elExport → WAR File y guarde su archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Prueba una URL -http://localhost:8080/HelloWeb/user y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Debería ver la siguiente pantalla, si todo está bien con su aplicación web Spring.
El siguiente ejemplo muestra cómo usar Listbox en formularios usando el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los pasos siguientes para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java User, UserController en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista user.jsp, users.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String username;
private String password;
private String address;
private boolean receivePaper;
private String [] favoriteFrameworks;
private String gender;
private String favoriteNumber;
private String country;
private String [] skills;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
public boolean isReceivePaper() {
return receivePaper;
}
public void setReceivePaper(boolean receivePaper) {
this.receivePaper = receivePaper;
}
public String[] getFavoriteFrameworks() {
return favoriteFrameworks;
}
public void setFavoriteFrameworks(String[] favoriteFrameworks) {
this.favoriteFrameworks = favoriteFrameworks;
}
public String getGender() {
return gender;
}
public void setGender(String gender) {
this.gender = gender;
}
public String getFavoriteNumber() {
return favoriteNumber;
}
public void setFavoriteNumber(String favoriteNumber) {
this.favoriteNumber = favoriteNumber;
}
public String getCountry() {
return country;
}
public void setCountry(String country) {
this.country = country;
}
public String[] getSkills() {
return skills;
}
public void setSkills(String[] skills) {
this.skills = skills;
}
}
UserController.java
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class UserController {
@RequestMapping(value = "/user", method = RequestMethod.GET)
public ModelAndView user() {
User user = new User();
user.setFavoriteFrameworks((new String []{"Spring MVC","Struts 2"}));
user.setGender("M");
ModelAndView modelAndView = new ModelAndView("user", "command", user);
return modelAndView;
}
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public String addUser(@ModelAttribute("SpringWeb")User user,
ModelMap model) {
model.addAttribute("username", user.getUsername());
model.addAttribute("password", user.getPassword());
model.addAttribute("address", user.getAddress());
model.addAttribute("receivePaper", user.isReceivePaper());
model.addAttribute("favoriteFrameworks", user.getFavoriteFrameworks());
model.addAttribute("gender", user.getGender());
model.addAttribute("favoriteNumber", user.getFavoriteNumber());
model.addAttribute("country", user.getCountry());
model.addAttribute("skills", user.getSkills());
return "users";
}
@ModelAttribute("webFrameworkList")
public List<String> getWebFrameworkList() {
List<String> webFrameworkList = new ArrayList<String>();
webFrameworkList.add("Spring MVC");
webFrameworkList.add("Struts 1");
webFrameworkList.add("Struts 2");
webFrameworkList.add("Apache Wicket");
return webFrameworkList;
}
@ModelAttribute("numbersList")
public List<String> getNumbersList() {
List<String> numbersList = new ArrayList<String>();
numbersList.add("1");
numbersList.add("2");
numbersList.add("3");
numbersList.add("4");
return numbersList;
}
@ModelAttribute("countryList")
public Map<String, String> getCountryList() {
Map<String, String> countryList = new HashMap<String, String>();
countryList.put("US", "United States");
countryList.put("CH", "China");
countryList.put("SG", "Singapore");
countryList.put("MY", "Malaysia");
return countryList;
}
@ModelAttribute("skillsList")
public Map<String, String> getSkillsList() {
Map<String, String> skillList = new HashMap<String, String>();
skillList.put("Hibernate", "Hibernate");
skillList.put("Spring", "Spring");
skillList.put("Apache Wicket", "Apache Wicket");
skillList.put("Struts", "Struts");
return skillList;
}
}
Aquí, para el primer método de servicio user(), hemos pasado un espacio en blanco Userobjeto en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Entonces, cuando eluser() se llama al método, devuelve el user.jsp ver.
El segundo método de servicio addUser() se llamará contra un método POST en el HelloWeb/addUserURL. Preparará su objeto modelo en función de la información enviada. Finalmente, la vista "usuarios" se devolverá desde el método de servicio, lo que dará como resultado la renderización de users.jsp.
user.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>User Information</h2>
<form:form method = "POST" action = "/HelloWeb/addUser">
<table>
<tr>
<td><form:label path = "username">User Name</form:label></td>
<td><form:input path = "username" /></td>
</tr>
<tr>
<td><form:label path = "password">Age</form:label></td>
<td><form:password path = "password" /></td>
</tr>
<tr>
<td><form:label path = "address">Address</form:label></td>
<td><form:textarea path = "address" rows = "5" cols = "30" /></td>
</tr>
<tr>
<td><form:label path = "receivePaper">Subscribe Newsletter</form:label></td>
<td><form:checkbox path = "receivePaper" /></td>
</tr>
<tr>
<td><form:label path = "favoriteFrameworks">Favorite Web Frameworks</form:label></td>
<td><form:checkboxes items = "${webFrameworkList}" path = "favoriteFrameworks" /></td> </tr> <tr> <td><form:label path = "gender">Gender</form:label></td> <td> <form:radiobutton path = "gender" value = "M" label = "Male" /> <form:radiobutton path = "gender" value = "F" label = "Female" /> </td> </tr> <tr> <td><form:label path = "favoriteNumber">Favorite Number</form:label></td> <td> <form:radiobuttons path = "favoriteNumber" items = "${numbersList}" />
</td>
</tr>
<tr>
<td><form:label path = "country">Country</form:label></td>
<td>
<form:select path = "country">
<form:option value = "NONE" label = "Select"/>
<form:options items = "${countryList}" /> </form:select> </td> </tr> <tr> <td><form:label path = "skills">Skills</form:label></td> <td> <form:select path = "skills" items = "${skillsList}"
multiple = "true" />
</td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando un <form:select /> etiqueta, con el atributo multiple=truepara representar un cuadro de lista HTML. Por ejemplo
<form:select path = "skills" items = "${skillsList}" multiple = "true" />
Representará el siguiente contenido HTML.
<select id = "skills" name = "skills" multiple = "multiple">
<option value = "Struts">Struts</option>
<option value = "Hibernate">Hibernate</option>
<option value = "Apache Wicket">Apache Wicket</option>
<option value = "Spring">Spring</option>
</select>
<input type = "hidden" name = "_skills" value = "1"/>
users.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted User Information</h2>
<table>
<tr>
<td>Username</td>
<td>${username}</td>
</tr>
<tr>
<td>Password</td>
<td>${password}</td> </tr> <tr> <td>Address</td> <td>${address}</td>
</tr>
<tr>
<td>Subscribed to Newsletter</td>
<td>${receivePaper}</td> </tr> <tr> <td>Favorite Web Frameworks</td> <td> <% String[] favoriteFrameworks = (String[])request.getAttribute("favoriteFrameworks"); for(String framework: favoriteFrameworks) { out.println(framework); } %></td> </tr> <tr> <td>Gender</td> <td>${(gender=="M"? "Male" : "Female")}</td>
</tr>
<tr>
<td>Favourite Number</td>
<td>${favoriteNumber}</td> </tr> <tr> <td>Country</td> <td>${country}</td>
</tr>
<tr>
<td>Skills</td>
<td> <% String[] skills = (String[])request.getAttribute("skills");
for(String skill: skills) {
out.println(skill);
}
%></td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File y guarde el archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/HelloWeb/user y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Debería ver la siguiente pantalla, si todo está bien con su aplicación web Spring.
El siguiente ejemplo describe cómo usar un campo oculto en formularios usando el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases de Java Student, StudentController en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista student.jsp, result.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
Student.java
package com.tutorialspoint;
public class Student {
private Integer age;
private String name;
private Integer id;
public void setAge(Integer age) {
this.age = age;
}
public Integer getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
}
StudentController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.ui.ModelMap;
@Controller
public class StudentController {
@RequestMapping(value = "/student", method = RequestMethod.GET)
public ModelAndView student() {
return new ModelAndView("student", "command", new Student());
}
@RequestMapping(value = "/addStudent", method = RequestMethod.POST)
public String addStudent(@ModelAttribute("SpringWeb")Student student,
ModelMap model) {
model.addAttribute("name", student.getName());
model.addAttribute("age", student.getAge());
model.addAttribute("id", student.getId());
return "result";
}
}
Aquí, para el primer método de servicio student(), hemos pasado un espacio en blanco Studentobjecten el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Entonces, cuando elstudent() se llama al método, devuelve el student.jsp ver.
El segundo método de servicio addStudent() se llamará contra un método POST en el HelloWeb/addStudentURL. Preparará su objeto modelo en función de la información enviada. Finalmente, se devolverá una vista de "resultado" del método de servicio, lo que dará como resultado la representación de result.jsp
student.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Student Information</h2>
<form:form method = "POST" action = "/HelloWeb/addStudent">
<table>
<tr>
<td><form:label path = "name">Name</form:label></td>
<td><form:input path = "name" /></td>
</tr>
<tr>
<td><form:label path = "age">Age</form:label></td>
<td><form:input path = "age" /></td>
</tr>
<tr>
<td>< </td>
<td><form:hidden path = "id" value = "1" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando el <form:hidden /> etiqueta para representar un campo oculto HTML.
Por ejemplo
<form:hidden path = "id" value = "1"/>
Representará el siguiente contenido HTML.
<input id = "id" name = "id" type = "hidden" value = "1"/>
result.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted Student Information</h2>
<table>
<tr>
<td>Name</td>
<td>${name}</td> </tr> <tr> <td>Age</td> <td>${age}</td>
</tr>
<tr>
<td>ID</td>
<td>${id}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación y useExport → WAR File opción y guarda tu HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/HelloWeb/student y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Veremos la siguiente pantalla, si todo está bien con su aplicación web Spring.
El siguiente ejemplo muestra cómo usar el manejo de errores y los validadores en formularios usando Spring Web MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases de Java Student, StudentController y StudentValidator en el paquete com.tutorialspoint. |
3 | Cree archivos de vista addStudent.jsp, result.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
Student.java
package com.tutorialspoint;
public class Student {
private Integer age;
private String name;
private Integer id;
public void setAge(Integer age) {
this.age = age;
}
public Integer getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
}
StudentValidator.java
package com.tutorialspoint;
import org.springframework.validation.Errors;
import org.springframework.validation.ValidationUtils;
import org.springframework.validation.Validator;
public class StudentValidator implements Validator {
@Override
public boolean supports(Class<?> clazz) {
return Student.class.isAssignableFrom(clazz);
}
@Override
public void validate(Object target, Errors errors) {
ValidationUtils.rejectIfEmptyOrWhitespace(errors,
"name", "required.name","Field name is required.");
}
}
StudentController.java
package com.tutorialspoint;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.validation.Validator;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.WebDataBinder;
import org.springframework.web.bind.annotation.InitBinder;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class StudentController {
@Autowired
@Qualifier("studentValidator")
private Validator validator;
@InitBinder
private void initBinder(WebDataBinder binder) {
binder.setValidator(validator);
}
@RequestMapping(value = "/addStudent", method = RequestMethod.GET)
public ModelAndView student() {
return new ModelAndView("addStudent", "command", new Student());
}
@ModelAttribute("student")
public Student createStudentModel() {
return new Student();
}
@RequestMapping(value = "/addStudent", method = RequestMethod.POST)
public String addStudent(@ModelAttribute("student") @Validated Student student,
BindingResult bindingResult, Model model) {
if (bindingResult.hasErrors()) {
return "addStudent";
}
model.addAttribute("name", student.getName());
model.addAttribute("age", student.getAge());
model.addAttribute("id", student.getId());
return "result";
}
}
HelloWeb-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.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
<bean id = "studentValidator" class = "com.tutorialspoint.StudentValidator" />
</beans>
Aquí, para el primer método de servicio student(), hemos pasado un Studentobject en blanco en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <form: form> en su archivo JSP. Entonces, cuando se llama al método student (), devuelveaddStudent.jsp ver.
El segundo método de servicio addStudent() se llamará contra un método POST en el HelloWeb/addStudentURL. Preparará su objeto modelo en función de la información enviada. Finalmente, se devolverá una vista de "resultado" del método de servicio, que dará como resultado la representación del archivo result.jsp. En caso de que se generen errores con el validador, se devuelve la misma vista "addStudent", Spring inyecta automáticamente mensajes de error deBindingResult en vista.
addStudent.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<style>
.error {
color: #ff0000;
}
.errorblock {
color: #000;
background-color: #ffEEEE;
border: 3px solid #ff0000;
padding: 8px;
margin: 16px;
}
</style>
<body>
<h2>Student Information</h2>
<form:form method = "POST" action = "/HelloWeb/addStudent" commandName = "student">
<form:errors path = "*" cssClass = "errorblock" element = "div" />
<table>
<tr>
<td><form:label path = "name">Name</form:label></td>
<td><form:input path = "name" /></td>
<td><form:errors path = "name" cssClass = "error" /></td>
</tr>
<tr>
<td><form:label path = "age">Age</form:label></td>
<td><form:input path = "age" /></td>
</tr>
<tr>
<td><form:label path = "id">id</form:label></td>
<td><form:input path = "id" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí estamos usando <form:errors />etiqueta con ruta = "*" para mostrar mensajes de error. Por ejemplo
<form:errors path = "*" cssClass = "errorblock" element = "div" />
Presentará los mensajes de error para todas las validaciones de entrada.
Estamos usando <form:errors />etiqueta con ruta = "nombre" para mostrar un mensaje de error para el campo de nombre. Por ejemplo
<form:errors path = "name" cssClass = "error" />
Presentará mensajes de error para las validaciones del campo de nombre.
result.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted Student Information</h2>
<table>
<tr>
<td>Name</td>
<td>${name}</td>
</tr>
<tr>
<td>Age</td>
<td>${age}</td> </tr> <tr> <td>ID</td> <td>${id}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Prueba una URL -http://localhost:8080/HelloWeb/addStudent y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Debería ver la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo muestra cómo usar File Upload Control en formularios usando el marco Spring Web MVC. Para empezar, tengamos un Eclipse IDE en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre HelloWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree clases Java FileModel, FileUploadController en el paquete com.tutorialspoint. |
3 | Cree archivos de vista fileUpload.jsp, success.jsp en la subcarpeta jsp. |
4 | Crea una carpeta temp en la subcarpeta WebContent. |
5 | Descargue la biblioteca Apache Commons FileUpload commons-fileupload.jar y la biblioteca Apache Commons IO commons-io.jar . Ponlos en tu CLASSPATH. |
6 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
FileModel.java
package com.tutorialspoint;
import org.springframework.web.multipart.MultipartFile;
public class FileModel {
private MultipartFile file;
public MultipartFile getFile() {
return file;
}
public void setFile(MultipartFile file) {
this.file = file;
}
}
FileUploadController.java
package com.tutorialspoint;
import java.io.File;
import java.io.IOException;
import javax.servlet.ServletContext;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.util.FileCopyUtils;
import org.springframework.validation.BindingResult;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class FileUploadController {
@Autowired
ServletContext context;
@RequestMapping(value = "/fileUploadPage", method = RequestMethod.GET)
public ModelAndView fileUploadPage() {
FileModel file = new FileModel();
ModelAndView modelAndView = new ModelAndView("fileUpload", "command", file);
return modelAndView;
}
@RequestMapping(value="/fileUploadPage", method = RequestMethod.POST)
public String fileUpload(@Validated FileModel file, BindingResult result, ModelMap model) throws IOException {
if (result.hasErrors()) {
System.out.println("validation errors");
return "fileUploadPage";
} else {
System.out.println("Fetching file");
MultipartFile multipartFile = file.getFile();
String uploadPath = context.getRealPath("") + File.separator + "temp" + File.separator;
//Now do something with file...
FileCopyUtils.copy(file.getFile().getBytes(), new File(uploadPath+file.getFile().getOriginalFilename()));
String fileName = multipartFile.getOriginalFilename();
model.addAttribute("fileName", fileName);
return "success";
}
}
}
HelloWeb-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.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
<bean id = "multipartResolver"
class = "org.springframework.web.multipart.commons.CommonsMultipartResolver" />
</beans>
Aquí, para el primer método de servicio fileUploadPage(), hemos pasado un espacio en blanco FileModelobjeto en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Así que cuandofileUploadPage() se llama al método, devuelve fileUpload.jsp ver.
El segundo método de servicio fileUpload() se llamará contra un método POST en el HelloWeb/fileUploadPageURL. Preparará el archivo para cargar en función de la información enviada. Finalmente, se devolverá una vista de "éxito" del método de servicio, lo que dará como resultado la representación de success.jsp.
fileUpload.jsp
<%@ page contentType="text/html; charset = UTF-8" %>
<%@ taglib prefix = "form" uri = "http://www.springframework.org/tags/form"%>
<html>
<head>
<title>File Upload Example</title>
</head>
<body>
<form:form method = "POST" modelAttribute = "fileUpload"
enctype = "multipart/form-data">
Please select a file to upload :
<input type = "file" name = "file" />
<input type = "submit" value = "upload" />
</form:form>
</body>
</html>
Aquí, estamos usando modelAttribute atributo con value = "fileUpload" para mapear el control de carga de archivos con el modelo de servidor.
success.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>File Upload Example</title>
</head>
<body>
FileName :
lt;b> ${fileName} </b> - Uploaded Successfully.
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File y guarde el archivo HelloWeb.war en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URLhttp://localhost:8080/HelloWeb/fileUploadPage y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Después de enviar la información requerida, haga clic en el botón enviar para enviar el formulario. Debería ver la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo muestra cómo usar la asignación de manejador de URL de nombre de bean usando Spring Web MVC Framework. losBeanNameUrlHandlerMapping class es la clase de mapeo del manejador predeterminado, que mapea las solicitudes de URL al nombre de los beans mencionados en la configuración.
<beans>
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean name = "/helloWorld.htm"
class = "com.tutorialspoint.HelloController" />
<bean name = "/hello*"
class = "com.tutorialspoint.HelloController" />
<bean name = "/welcome.htm"
class = "com.tutorialspoint.WelcomeController"/>
</beans>
Por ejemplo, usando la configuración anterior, si URI
/helloWorld.htm o / hello {se solicita cualquier carta} .htm, DispatcherServlet reenviará la solicitud al HelloController.
se solicita /welcome.htm, DispatcherServlet enviará la solicitud al WelcomeController.
Se solicita /welcome1.htm, DispatcherServlet no encontrará ningún controlador y el servidor arrojará un error de estado 404.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree clases de Java HelloController, WelcomeController en el paquete com.tutorialspoint. |
3 | Cree archivos de vista hello.jsp, welcome.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de todos los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
HelloController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class HelloController extends AbstractController{
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("hello");
model.addObject("message", "Hello World!");
return model;
}
}
WelcomeController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class WelcomeController extends AbstractController{
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("welcome");
model.addObject("message", "Welcome!");
return model;
}
}
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">
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean name = "/helloWorld.htm"
class = "com.tutorialspoint.HelloController" />
<bean name = "/hello*"
class = "com.tutorialspoint.HelloController" />
<bean name = "/welcome.htm"
class = "com.tutorialspoint.WelcomeController"/>
</beans>
hello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
welcome.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Welcome</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/helloWorld.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL - http://localhost:8080/TestWeb/hello.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL http://localhost:8080/TestWeb/welcome.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL http://localhost:8080/TestWeb/welcome1.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo muestra cómo usar la asignación de controlador de nombre de clase de controlador usando el marco Spring Web MVC. losControllerClassNameHandlerMappingclass es la clase de mapeo de manejadores basada en convenciones, que mapea las solicitudes de URL al nombre de los controladores mencionados en la configuración. Esta clase toma los nombres de los controladores y los convierte a minúsculas con una "/" inicial.
Por ejemplo, HelloController se asigna a la URL "/ hello *".
<beans>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping"/>
<bean class = "com.tutorialspoint.HelloController" />
<bean class = "com.tutorialspoint.WelcomeController"/>
</beans>
Por ejemplo, usando la configuración anterior, si URI
/helloWorld.htm o / hello {se solicita cualquier carta} .htm, DispatcherServlet reenviará la solicitud al HelloController.
se solicita /welcome.htm, DispatcherServlet enviará la solicitud al WelcomeController.
Se solicita /Welcome.htm donde W está en mayúsculas, DispatcherServlet no encontrará ningún controlador y el servidor arrojará un error de estado 404.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los pasos siguientes para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases de Java HelloController y WelcomeController en el paquete com.tutorialspoint. |
3 | Cree archivos de vista hello.jsp, welcome.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
HelloController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class HelloController extends AbstractController{
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("hello");
model.addObject("message", "Hello World!");
return model;
}
}
WelcomeController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class WelcomeController extends AbstractController{
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("welcome");
model.addObject("message", "Welcome!");
return model;
}
}
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">
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping"/>
<bean class = "com.tutorialspoint.HelloController" />
<bean class = "com.tutorialspoint.WelcomeController"/>
</beans>
hello.jsp
<%@ page contentType="text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
welcome.jsp
<%@ page contentType = "text/html; charset=UTF-8" %>
<html>
<head>
<title>Welcome</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en la aplicación, use elExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/helloWorld.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL http://localhost:8080/TestWeb/hello.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL http://localhost:8080/TestWeb/welcome.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL http://localhost:8080/TestWeb/Welcome.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo muestra cómo usar la asignación de controlador de URL simple con el marco Spring Web MVC. La clase SimpleUrlHandlerMapping ayuda a mapear URL explícitamente con sus controladores respectivamente.
<beans>
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name = "mappings">
<props>
<prop key = "/welcome.htm">welcomeController</prop>
<prop key = "/helloWorld.htm">helloController</prop>
</props>
</property>
</bean>
<bean id = "helloController" class = "com.tutorialspoint.HelloController" />
<bean id = "welcomeController" class = "com.tutorialspoint.WelcomeController"/>
</beans>
Por ejemplo, usando la configuración anterior, si URI
Se solicita /helloWorld.htm, DispatcherServlet reenviará la solicitud al HelloController.
se solicita /welcome.htm, DispatcherServlet enviará la solicitud al WelcomeController.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Crea un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases de Java HelloController y WelcomeController en el paquete com.tutorialspoint. |
3 | Cree archivos de vista hello.jsp y welcome.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
HelloController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class HelloController extends AbstractController{
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("hello");
model.addObject("message", "Hello World!");
return model;
}
}
WelcomeController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class WelcomeController extends AbstractController{
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("welcome");
model.addObject("message", "Welcome!");
return model;
}
}
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">
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name = "mappings">
<props>
<prop key = "/welcome.htm">welcomeController</prop>
<prop key = "/helloWorld.htm">helloController</prop>
</props>
</property>
</bean>
<bean id = "helloController" class = "com.tutorialspoint.HelloController" />
<bean id = "welcomeController" class = "com.tutorialspoint.WelcomeController"/>
</beans>
hello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
welcome.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Welcome</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, use elExport → WAR File opción y guarda tu TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/helloWorld.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL http://localhost:8080/TestWeb/welcome.htm y debería ver el siguiente resultado si todo está bien con su aplicación web Spring.
El siguiente ejemplo muestra cómo usar el controlador de acción múltiple usando el marco Spring Web MVC. losMultiActionController La clase ayuda a mapear múltiples URL con sus métodos en un solo controlador respectivamente.
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("home");
model.addObject("message", "Home");
return model;
}
public ModelAndView add(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Add");
return model;
}
public ModelAndView remove(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Remove");
return model;
}
}
<bean class = "org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean name = "/home.htm" class = "com.tutorialspoint.UserController" />
<bean name = "/user/*.htm" class = "com.tutorialspoint.UserController" />
Por ejemplo, usando la configuración anterior, si URI -
Se solicita /home.htm, DispatcherServlet reenviará la solicitud al UserController home() método.
Se solicita user / add.htm, DispatcherServlet enviará la solicitud al UserController add() método.
user / remove.htm es solicitado, DispatcherServlet reenviará la solicitud al UserController remove() método.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Crea un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un UserController de clase Java en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista home.jsp y user.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
UserController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("home");
model.addObject("message", "Home");
return model;
}
public ModelAndView add(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Add");
return model;
}
public ModelAndView remove(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Remove");
return model;
}
}
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">
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean name = "/home.htm"
class = "com.tutorialspoint.UserController" />
<bean name = "/user/*.htm"
class = "com.tutorialspoint.UserController" />
</beans>
home.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<meta http-equiv = "Content-Type" content = "text/html; charset = ISO-8859-1">
<title>Home</title>
</head>
<body>
<a href = "user/add.htm" >Add</a> <br>
<a href = "user/remove.htm" >Remove</a>
</body>
</html>
user.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Ahora, prueba con una URL:http://localhost:8080/TestWeb/home.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
Prueba una URL http://localhost:8080/TestWeb/user/add.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo muestra cómo usar el método de resolución de nombre de método de propiedades de un controlador de acción múltiple usando el marco Spring Web MVC. losMultiActionController La clase ayuda a mapear múltiples URL con sus métodos en un solo controlador respectivamente.
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Home");
return model;
}
public ModelAndView add(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Add");
return model;
}
public ModelAndView remove(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Remove");
return model;
}
}
<bean class = "com.tutorialspoint.UserController">
<property name = "methodNameResolver">
<bean class = "org.springframework.web.servlet.mvc.multiaction.PropertiesMethodNameResolver">
<property name = "mappings">
<props>
<prop key = "/user/home.htm">home</prop>
<prop key = "/user/add.htm">add</prop>
<prop key = "/user/remove.htm">update</prop>
</props>
</property>
</bean>
</property>
</bean>
Por ejemplo, usando la configuración anterior, si URI -
Se solicita /user/home.htm, DispatcherServlet reenviará la solicitud al UserController home() método.
Se solicita /user/add.htm, DispatcherServlet reenviará la solicitud al UserController add() método.
Se solicita /user/remove.htm, DispatcherServlet reenviará la solicitud al UserController remove() método.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree UserController de clase Java en el paquete com.tutorialspoint. |
3 | Cree un archivo de vista user.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
UserController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Home");
return model;
}
public ModelAndView add(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Add");
return model;
}
public ModelAndView remove(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Remove");
return model;
}
}
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">
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping">
<property name = "caseSensitive" value = "true" />
</bean>
<bean class = "com.tutorialspoint.UserController">
<property name = "methodNameResolver">
<bean class = "org.springframework.web.servlet.mvc.multiaction.PropertiesMethodNameResolver">
<property name = "mappings">
<props>
<prop key = "/user/home.htm">home</prop>
<prop key = "/user/add.htm">add</prop>
<prop key = "/user/remove.htm">update</prop>
</props>
</property>
</bean>
</property>
</bean>
</beans>
user.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Ahora, prueba con una URL:http://localhost:8080/TestWeb/user/add.htm y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo muestra cómo usar el Resolver nombre de método de parámetro de un controlador de acción múltiple usando el marco Spring Web MVC. losMultiActionController La clase ayuda a mapear múltiples URL con sus métodos en un solo controlador respectivamente.
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Home");
return model;
}
public ModelAndView add(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Add");
return model;
}
public ModelAndView remove(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Remove");
return model;
}
}
<bean class = "com.tutorialspoint.UserController">
<property name = "methodNameResolver">
<bean class = "org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
<property name = "paramName" value = "action"/>
</bean>
</property>
</bean>
Por ejemplo, usando la configuración anterior, si URI -
/user/*.htm?action=home es solicitado, DispatcherServlet enviará la solicitud al UserController home() método.
Se solicita /user/*.htm?action=add, DispatcherServlet reenviará la solicitud al UserController add() método.
Se solicita /user/*.htm?action=remove, DispatcherServlet enviará la solicitud al UserController remove() método.
Para empezar, tengamos un Eclipse IDE en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un UserController de clase Java en el paquete com.tutorialspoint. |
3 | Cree un archivo de vista user.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
UserController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Home");
return model;
}
public ModelAndView add(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Add");
return model;
}
public ModelAndView remove(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Remove");
return model;
}
}
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">
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping">
<property name = "caseSensitive" value = "true" />
</bean>
<bean class = "com.tutorialspoint.UserController">
<property name = "methodNameResolver">
<bean class = "org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
<property name = "paramName" value = "action"/>
</bean>
</property>
</bean>
</beans>
user.jsp
<%@ page contentType="text/html; charset=UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Ahora, prueba con una URL:http://localhost:8080/TestWeb/user/test.htm?action=home y veremos la siguiente pantalla, si todo está bien con la aplicación web Spring.
El siguiente ejemplo muestra cómo usar el método Controlador de vista parametrizable de un controlador de acción múltiple usando el marco Spring Web MVC. La Vista parametrizable permite mapear una página web con una solicitud.
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Home");
return model;
}
}
<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<value>
index.htm=userController
</value>
</property>
</bean>
<bean id="userController" class="org.springframework.web.servlet.mvc.ParameterizableViewController">
<property name="viewName" value="user"/>
</bean>
Por ejemplo, usando la configuración anterior, si URI.
/index.htm, DispatcherServlet reenviará la solicitud al UserController controlador con viewName establecido como user.jsp.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un UserController de clase Java en el paquete com.tutorialspoint. |
3 | Cree un archivo de vista user.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
UserController.java
package com.tutorialspoint;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;
public class UserController extends MultiActionController{
public ModelAndView home(HttpServletRequest request,
HttpServletResponse response) throws Exception {
ModelAndView model = new ModelAndView("user");
model.addObject("message", "Home");
return model;
}
}
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">
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
<bean class = "org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name = "mappings">
<value>
index.htm = userController
</value>
</property>
</bean>
<bean id = "userController" class = "org.springframework.web.servlet.mvc.ParameterizableViewController">
<property name = "viewName" value="user"/>
</bean>
</beans>
user.jsp
<%@ page contentType="text/html; charset=UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>Hello World</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de que puede acceder a otras páginas web desde la carpeta de aplicaciones web utilizando un navegador estándar. Ahora, prueba con una URL:http://localhost:8080/TestWeb/index.htm y verá la siguiente pantalla, si todo está bien con la aplicación web Spring.
los InternalResourceViewResolverse utiliza para resolver el URI proporcionado en el URI real. El siguiente ejemplo muestra cómo usar InternalResourceViewResolver usando Spring Web MVC Framework. InternalResourceViewResolver permite mapear páginas web con solicitudes.
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";
}
}
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/"/>
<property name = "suffix" value = ".jsp"/>
</bean>
Por ejemplo, usando la configuración anterior, si URI
Se solicita / hello, DispatcherServlet enviará la solicitud al prefijo + nombre de vista + sufijo = /WEB-INF/jsp/hello.jsp.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y luego consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspointas explicado en el capítulo Spring MVC - Hello World Example. |
2 | Cree un HelloController de clases de Java en el paquete com.tutorialspoint. |
3 | Cree un archivo de vista hello.jsp en la subcarpeta jsp. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
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.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
</beans>
hello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Intente acceder a la URL -http://localhost:8080/TestWeb/hello y si todo va bien con la aplicación web Spring, veremos la siguiente pantalla.
XmlViewResolver se utiliza para resolver los nombres de las vistas mediante los beans de vista definidos en el archivo xml. El siguiente ejemplo muestra cómo usar XmlViewResolver usando el marco Spring Web MVC.
TestWeb-servlet.xml
<bean class = "org.springframework.web.servlet.view.XmlViewResolver">
<property name = "location">
<value>/WEB-INF/views.xml</value>
</property>
</bean>
views.xml
<bean id = "hello"
class = "org.springframework.web.servlet.view.JstlView">
<property name = "url" value = "/WEB-INF/jsp/hello.jsp" />
</bean>
Por ejemplo, usando la configuración anterior, si URI -
/ hello se solicita, DispatcherServlet enviará la solicitud al hello.jsp definido por bean hello en view.xml.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un HelloController de clase Java en el paquete com.tutorialspoint. |
3 | Cree un archivo de vista hello.jsp en la subcarpeta jsp. |
4 | Descargue la biblioteca JSTL jstl.jar . Ponlo en tu CLASSPATH. |
5 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
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.XmlViewResolver">
<property name = "location">
<value>/WEB-INF/views.xml</value>
</property>
</bean>
</beans>
views.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">
<bean id = "hello"
class = "org.springframework.web.servlet.view.JstlView">
<property name = "url" value = "/WEB-INF/jsp/hello.jsp" />
</bean>
</beans>
hello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Intente acceder a la URL -http://localhost:8080/HelloWeb/hello y si todo va bien con la aplicación web Spring, veremos la siguiente pantalla.
los ResourceBundleViewResolverse utiliza para resolver los nombres de las vistas utilizando beans de vista definidos en el archivo de propiedades. El siguiente ejemplo muestra cómo usar ResourceBundleViewResolver usando Spring Web MVC Framework.
TestWeb-servlet.xml
<bean class = "org.springframework.web.servlet.view.ResourceBundleViewResolver">
<property name = "basename" value = "views" />
</bean>
Aquí el basenamehace referencia al nombre del paquete de recursos, que incluye las vistas. El nombre predeterminado del paquete de recursos esviews.properties, que puede anularse mediante la propiedad basename.
vistas.propiedades
hello.(class) = org.springframework.web.servlet.view.JstlView
hello.url = /WEB-INF/jsp/hello.jsp
Por ejemplo, usando la configuración anterior, si URI -
Se solicita / hello, DispatcherServlet enviará la solicitud al hello.jsp definido por bean hello en views.properties.
Aquí, "hola" es el nombre de la vista que debe coincidir. Mientras,class se refiere al tipo de vista y la URL es la ubicación de la vista.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un HelloController de clase Java en el paquete com.tutorialspoint. |
3 | Cree un archivo de vista hello.jsp en la subcarpeta jsp. |
4 | Cree un archivo de propiedades views.properties en la carpeta src. |
5 | Descargue la biblioteca JSTL jstl.jar . Ponlo en tu CLASSPATH. |
6 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
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>
vistas.propiedades
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 vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File y guarde su archivo HelloWeb.war en la carpeta webapps de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Intente acceder a la URL -http://localhost:8080/HelloWeb/hello y si todo va bien con la aplicación web Spring, veremos la siguiente pantalla.
En caso de que desee utilizar un solucionador de vistas múltiples en una aplicación Spring MVC, el orden de prioridad se puede establecer utilizando la propiedad order. El siguiente ejemplo muestra cómo utilizar elResourceBundleViewResolver y el InternalResourceViewResolver en Spring Web MVC Framework.
TestWeb-servlet.xml
<bean class = "org.springframework.web.servlet.view.ResourceBundleViewResolver">
<property name = "basename" value = "views" />
<property name = "order" value = "0" />
</bean>
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
<property name = "order" value = "1" />
</bean>
Aquí, la propiedad de orden define la clasificación de un solucionador de vistas. En esto, 0 es el primer resolutor y 1 es el siguiente resolutor y así sucesivamente.
vistas.propiedades
hello.(class) = org.springframework.web.servlet.view.JstlView
hello.url = /WEB-INF/jsp/hello.jsp
Por ejemplo, usando la configuración anterior, si URI -
Se solicita / hello, DispatcherServlet enviará la solicitud al hello.jsp definido por bean hello en views.properties.
Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un HelloController de clase Java en el paquete com.tutorialspoint. |
3 | Cree un archivo de vista hello.jsp en la subcarpeta jsp. |
4 | Cree un archivo de propiedades views.properties en la carpeta SRC. |
5 | Descargue la biblioteca JSTL jstl.jar . Ponlo en tu CLASSPATH. |
6 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
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" />
<property name = "order" value = "0" />
</bean>
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
<property name = "order" value = "1" />
</bean>
</beans>
vistas.propiedades
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 vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarda tu HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Intente acceder a la URL -http://localhost:8080/HelloWeb/hello, si todo está bien con la aplicación web Spring, veremos la siguiente pantalla.
El siguiente ejemplo muestra cómo usar el manejo de errores y los validadores en formularios que usan el marco Spring Web MVC. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Crea un proyecto con el nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases de Java Student, StudentController y StudentValidator en el paquete com.tutorialspoint. |
3 | Cree los archivos de vista addStudent.jsp y result.jsp en la subcarpeta jsp. |
4 | Descargar la biblioteca de Hibernate Validator Hibernate Validator . Extraiga hibernate-validator-5.3.4.Final.jar y las dependencias requeridas presentes en la carpeta requerida del archivo zip descargado. Ponlos en tu CLASSPATH. |
5 | Cree un archivo de propiedades messages.properties en la carpeta SRC. |
6 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
Student.java
package com.tutorialspoint;
import org.hibernate.validator.constraints.NotEmpty;
import org.hibernate.validator.constraints.Range;
public class Student {
@Range(min = 1, max = 150)
private Integer age;
@NotEmpty
private String name;
private Integer id;
public void setAge(Integer age) {
this.age = age;
}
public Integer getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getId() {
return id;
}
}
StudentController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.validation.BindingResult;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class StudentController {
@RequestMapping(value = "/addStudent", method = RequestMethod.GET)
public ModelAndView student() {
return new ModelAndView("addStudent", "command", new Student());
}
@ModelAttribute("student")
public Student createStudentModel() {
return new Student();
}
@RequestMapping(value = "/addStudent", method = RequestMethod.POST)
public String addStudent(@ModelAttribute("student") @Validated Student student,
BindingResult bindingResult, Model model) {
if (bindingResult.hasErrors()) {
return "addStudent";
}
model.addAttribute("name", student.getName());
model.addAttribute("age", student.getAge());
model.addAttribute("id", student.getId());
return "result";
}
}
messages.properties
NotEmpty.student.name = Name is required!
Range.student.age = Age value must be between 1 and 150!
Aquí, la clave es <Annotation>. <object-name>. <attribute>. Valor es el mensaje que se mostrará.
TestWeb-servlet.xml
<beans xmlns = "http://www.springframework.org/schema/beans"
xmlns:context = "http://www.springframework.org/schema/context"
xmlns:mvc = "http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
<context:component-scan base-package = "com.tutorialspoint" />
<mvc:annotation-driven />
<bean class = "org.springframework.context.support.ResourceBundleMessageSource"
id = "messageSource">
<property name = "basename" value = "messages" />
</bean>
<bean class = "org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name = "prefix" value = "/WEB-INF/jsp/" />
<property name = "suffix" value = ".jsp" />
</bean>
</beans>
Aquí, para el primer método de servicio student(), hemos pasado un espacio en blanco Studentobject>en el objeto ModelAndView con el nombre "comando", porque el marco de Spring espera un objeto con el nombre "comando", si está utilizando etiquetas <formulario: formulario> en su archivo JSP. Entonces, cuando elstudent() se llama al método, devuelve addStudent.jsp ver.
El segundo método de servicio addStudent() se llamará contra un método POST en el HelloWeb/addStudentURL. Preparará su objeto modelo en función de la información enviada. Finalmente, se devolverá una vista de "resultado" del método de servicio, que dará como resultado la representación del archivo result.jsp. En caso de que se generen errores con el validador, se devuelve la misma vista "addStudent", Spring inyecta automáticamente mensajes de error deBindingResult en vista.
addStudent.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<style>
.error {
color: #ff0000;
}
.errorblock {
color: #000;
background-color: #ffEEEE;
border: 3px solid #ff0000;
padding: 8px;
margin: 16px;
}
</style>
<body>
<h2>Student Information</h2>
<form:form method = "POST" action = "/TestWeb/addStudent" commandName = "student">
<form:errors path = "*" cssClass = "errorblock" element = "div" />
<table>
<tr>
<td><form:label path = "name">Name</form:label></td>
<td><form:input path = "name" /></td>
<td><form:errors path = "name" cssClass = "error" /></td>
</tr>
<tr>
<td><form:label path = "age">Age</form:label></td>
<td><form:input path = "age" /></td>
<td><form:errors path = "age" cssClass = "error" /></td>
</tr>
<tr>
<td><form:label path = "id">id</form:label></td>
<td><form:input path = "id" /></td>
</tr>
<tr>
<td colspan = "2">
<input type = "submit" value = "Submit"/>
</td>
</tr>
</table>
</form:form>
</body>
</html>
Aquí, estamos usando la etiqueta <form: errors /> con path = "*" para mostrar mensajes de error. Por ejemplo
<form:errors path = "*" cssClass = "errorblock" element = "div" />
Presentará mensajes de error para todas las validaciones de entrada. Estamos usando la etiqueta <formulario: errores /> con ruta = "nombre" para mostrar un mensaje de error para el campo de nombre.
Por ejemplo
<form:errors path = "name" cssClass = "error" />
<form:errors path = "age" cssClass = "error" />
Presentará mensajes de error para las validaciones de campo de nombre y edad.
result.jsp
<%@taglib uri = "http://www.springframework.org/tags/form" prefix = "form"%>
<html>
<head>
<title>Spring MVC Form Handling</title>
</head>
<body>
<h2>Submitted Student Information</h2>
<table>
<tr>
<td>Name</td>
<td>${name}</td> </tr> <tr> <td>Age</td> <td>${age}</td>
</tr>
<tr>
<td>ID</td>
<td>${id}</td>
</tr>
</table>
</body>
</html>
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la HelloWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/addStudent y veremos la siguiente pantalla, si ha introducido valores no válidos.
El siguiente ejemplo muestra cómo generar RSS Feed usando Spring Web MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y luego consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con el nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java RSSMessage, RSSFeedViewer y RSSController en el paquete com.tutorialspoint. |
3 | Descargue la biblioteca de Roma Rome y sus dependencias rome-utils, jdom y slf4j desde la misma página del repositorio de maven. Ponlos en tu CLASSPATH. |
4 | Cree un archivo de propiedades messages.properties en la carpeta SRC. |
5 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
RSSMessage.java
package com.tutorialspoint;
import java.util.Date;
public class RSSMessage {
String title;
String url;
String summary;
Date createdDate;
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
public String getUrl() {
return url;
}
public void setUrl(String url) {
this.url = url;
}
public String getSummary() {
return summary;
}
public void setSummary(String summary) {
this.summary = summary;
}
public Date getCreatedDate() {
return createdDate;
}
public void setCreatedDate(Date createdDate) {
this.createdDate = createdDate;
}
}
RSSFeedViewer.java
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.view.feed.AbstractRssFeedView;
import com.rometools.rome.feed.rss.Channel;
import com.rometools.rome.feed.rss.Content;
import com.rometools.rome.feed.rss.Item;
public class RSSFeedViewer extends AbstractRssFeedView {
@Override
protected void buildFeedMetadata(Map<String, Object> model, Channel feed,
HttpServletRequest request) {
feed.setTitle("TutorialsPoint Dot Com");
feed.setDescription("Java Tutorials and Examples");
feed.setLink("http://www.tutorialspoint.com");
super.buildFeedMetadata(model, feed, request);
}
@Override
protected List<Item> buildFeedItems(Map<String, Object> model,
HttpServletRequest request, HttpServletResponse response) throws Exception {
List<RSSMessage> listContent = (List<RSSMessage>) model.get("feedContent");
List<Item> items = new ArrayList<Item>(listContent.size());
for(RSSMessage tempContent : listContent ){
Item item = new Item();
Content content = new Content();
content.setValue(tempContent.getSummary());
item.setContent(content);
item.setTitle(tempContent.getTitle());
item.setLink(tempContent.getUrl());
item.setPubDate(tempContent.getCreatedDate());
items.add(item);
}
return items;
}
}
RSSController.java
package com.tutorialspoint;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;
@Controller
public class RSSController {
@RequestMapping(value="/rssfeed", method = RequestMethod.GET)
public ModelAndView getFeedInRss() {
List<RSSMessage> items = new ArrayList<RSSMessage>();
RSSMessage content = new RSSMessage();
content.setTitle("Spring Tutorial");
content.setUrl("http://www.tutorialspoint/spring");
content.setSummary("Spring tutorial summary...");
content.setCreatedDate(new Date());
items.add(content);
RSSMessage content2 = new RSSMessage();
content2.setTitle("Spring MVC");
content2.setUrl("http://www.tutorialspoint/springmvc");
content2.setSummary("Spring MVC tutorial summary...");
content2.setCreatedDate(new Date());
items.add(content2);
ModelAndView mav = new ModelAndView();
mav.setViewName("rssViewer");
mav.addObject("feedContent", items);
return mav;
}
}
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.BeanNameViewResolver" />
<bean id = "rssViewer" class = "com.tutorialspoint.RSSFeedViewer" />
</beans>
Aquí, hemos creado una fuente RSS POJO RSSMessage y un visor de mensajes RSS, que amplía la AbstractRssFeedViewy anula su método. En RSSController, hemos generado una muestra de RSS.
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie su servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/rssfeed y veremos la siguiente pantalla.
El siguiente ejemplo muestra cómo generar XML usando Spring Web MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases de Java User y UserController en el paquete com.tutorialspoint. |
3 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;
@XmlRootElement(name = "user")
public class User {
private String name;
private int id;
public String getName() {
return name;
}
@XmlElement
public void setName(String name) {
this.name = name;
}
public int getId() {
return id;
}
@XmlElement
public void setId(int id) {
this.id = id;
}
}
UserController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
@RequestMapping("/user")
public class UserController {
@RequestMapping(value="{name}", method = RequestMethod.GET)
public @ResponseBody User getUser(@PathVariable String name) {
User user = new User();
user.setName(name);
user.setId(1);
return user;
}
}
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"
xmlns:mvc = "http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
<context:component-scan base-package = "com.tutorialspoint" />
<mvc:annotation-driven />
</beans>
Aquí, hemos creado un usuario POJO mapeado XML y en el UserController, hemos devuelto el usuario. Spring maneja automáticamente la conversión XML basada enRequestMapping.
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarda tu TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/mahesh y veremos la siguiente pantalla.
El siguiente ejemplo muestra cómo generar JSON utilizando Spring Web MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y consideremos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework:
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un usuario de clases Java , UserController en el paquete com.tutorialspoint . |
3 | Descargue las bibliotecas Jackson Jackson Core, Jackson Databind y Jackson Annotations desde la página del repositorio de maven. Ponlos en tu CLASSPATH. |
4 | El paso final es crear el contenido de todos los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
User.java
package com.tutorialspoint;
public class User {
private String name;
private int id;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
}
UserController.java
package com.tutorialspoint;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
@RequestMapping("/user")
public class UserController {
@RequestMapping(value="{name}", method = RequestMethod.GET)
public @ResponseBody User getUser(@PathVariable String name) {
User user = new User();
user.setName(name);
user.setId(1);
return user;
}
}
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"
xmlns:mvc = http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
<context:component-scan base-package = com.tutorialspoint" />
<mvc:annotation-driven />
</beans>
Aquí, hemos creado un usuario POJO simple y en UserController hemos devuelto el usuario. Spring maneja automáticamente la conversión JSON basada en RequestMapping y Jackson jar presentes en la ruta de clase.
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarda tu TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/mahesh y veremos la siguiente pantalla.
El siguiente ejemplo muestra cómo generar Excel usando Spring Web MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java UserExcelView y ExcelController en el paquete com.tutorialspoint. |
3 | Descargue la biblioteca Apache POI Apache POI desde la página del repositorio de maven. Ponlo en tu CLASSPATH. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
ExcelController.java
package com.tutorialspoint;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class ExcelController extends AbstractController {
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
//user data
Map<String,String> userData = new HashMap<String,String>();
userData.put("1", "Mahesh");
userData.put("2", "Suresh");
userData.put("3", "Ramesh");
userData.put("4", "Naresh");
return new ModelAndView("UserSummary","userData",userData);
}
}
UserExcelView.java
package com.tutorialspoint;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.springframework.web.servlet.view.document.AbstractExcelView;
public class UserExcelView extends AbstractExcelView {
@Override
protected void buildExcelDocument(Map<String, Object> model,
HSSFWorkbook workbook, HttpServletRequest request, HttpServletResponse response)
throws Exception {
Map<String,String> userData = (Map<String,String>) model.get("userData");
//create a wordsheet
HSSFSheet sheet = workbook.createSheet("User Report");
HSSFRow header = sheet.createRow(0);
header.createCell(0).setCellValue("Roll No");
header.createCell(1).setCellValue("Name");
int rowNum = 1;
for (Map.Entry<String, String> entry : userData.entrySet()) {
//create the row data
HSSFRow row = sheet.createRow(rowNum++);
row.createCell(0).setCellValue(entry.getKey());
row.createCell(1).setCellValue(entry.getValue());
}
}
}
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"
xmlns:mvc = "http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
<bean class = "org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping" />
<bean class = "com.tutorialspoint.ExcelController" />
<bean class = "org.springframework.web.servlet.view.XmlViewResolver">
<property name = "location">
<value>/WEB-INF/views.xml</value>
</property>
</bean>
</beans>
views.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">
<bean id = "UserSummary" class = "com.tutorialspoint.UserExcelView"></bean>
</beans>
Aquí, hemos creado un ExcelController y un ExcelView. La biblioteca de puntos de interés de Apache se ocupa de los formatos de archivo de Microsoft Office y convertirá los datos en un documento de Excel.
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/excel y veremos la siguiente pantalla.
El siguiente ejemplo muestra cómo generar un PDF usando Spring Web MVC Framework. Para empezar, tengamos un Eclipse IDE en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con un nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree las clases Java UserPDFView y PDFController en el paquete com.tutorialspoint. |
3 | Descargue la biblioteca iText - iText desde la página del repositorio de maven. Ponlo en tu CLASSPATH. |
4 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
PDFController.java
package com.tutorialspoint;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractController;
public class PDFController extends AbstractController {
@Override
protected ModelAndView handleRequestInternal(HttpServletRequest request,
HttpServletResponse response) throws Exception {
//user data
Map<String,String> userData = new HashMap<String,String>();
userData.put("1", "Mahesh");
userData.put("2", "Suresh");
userData.put("3", "Ramesh");
userData.put("4", "Naresh");
return new ModelAndView("UserSummary","userData",userData);
}
}
UserExcelView.java
package com.tutorialspoint;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.view.document.AbstractPdfView;
import com.lowagie.text.Document;
import com.lowagie.text.Table;
import com.lowagie.text.pdf.PdfWriter;
public class UserPDFView extends AbstractPdfView {
protected void buildPdfDocument(Map<String, Object> model, Document document,
PdfWriter pdfWriter, HttpServletRequest request, HttpServletResponse response)
throws Exception {
Map<String,String> userData = (Map<String,String>) model.get("userData");
Table table = new Table(2);
table.addCell("Roll No");
table.addCell("Name");
for (Map.Entry<String, String> entry : userData.entrySet()) {
table.addCell(entry.getKey());
table.addCell(entry.getValue());
}
document.add(table);
}
}
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"
xmlns:mvc = "http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
<bean class = "org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping" />
<bean class = "com.tutorialspoint.PDFController" />
<bean class = "org.springframework.web.servlet.view.XmlViewResolver">
<property name = "location">
<value>/WEB-INF/views.xml</value>
</property>
</bean>
</beans>
views.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">
<bean id = "UserSummary" class = "com.tutorialspoint.UserPDFView"></bean>
</beans>
Aquí, hemos creado un PDFController y UserPDFView. La biblioteca iText se ocupa de los formatos de archivo PDF y convertirá los datos en un documento PDF.
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarde la TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. También podemos probar la siguiente URL:http://localhost:8080/TestWeb/pdf y si todo sale según lo previsto, veremos la siguiente pantalla.
El siguiente ejemplo muestra cómo integrar LOG4J usando Spring Web MVC Framework. Para empezar, tengamos un IDE de Eclipse en funcionamiento y sigamos los siguientes pasos para desarrollar una aplicación web basada en formularios dinámicos utilizando Spring Web Framework.
Paso | Descripción |
---|---|
1 | Cree un proyecto con el nombre TestWeb en un paquete com.tutorialspoint como se explica en el capítulo Spring MVC - Hello World. |
2 | Cree un HelloController de clase Java en el paquete com.tutorialspoint. |
3 | Descargue la biblioteca de log4j LOG4J de la página del repositorio de maven. Ponlo en tu CLASSPATH. |
4 | Cree un log4j.properties en la carpeta SRC. |
5 | El paso final es crear el contenido de los archivos fuente y de configuración y exportar la aplicación como se explica a continuación. |
HelloController.java
package com.tutorialspoint;
import org.apache.log4j.Logger;
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{
private static final Logger LOGGER = Logger.getLogger(HelloController.class);
@RequestMapping(method = RequestMethod.GET)
public String printHello(ModelMap model) {
LOGGER.info("printHello started.");
//logs debug message
if(LOGGER.isDebugEnabled()){
LOGGER.debug("Inside: printHello");
}
//logs exception
LOGGER.error("Logging a sample exception", new Exception("Testing"));
model.addAttribute("message", "Hello Spring MVC Framework!");
LOGGER.info("printHello ended.");
return "hello";
}
}
log4j.properties
# Root logger option
log4j.rootLogger = DEBUG, stdout, file
# Redirect log messages to console
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
# Redirect log messages to a log file
log4j.appender.file = org.apache.log4j.RollingFileAppender
#outputs to Tomcat home
log4j.appender.file.File = ${catalina.home}/logs/myapp.log
log4j.appender.file.MaxFileSize = 5MB
log4j.appender.file.MaxBackupIndex = 10
log4j.appender.file.layout = org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n
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"
xmlns:mvc = "http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-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>
hello.jsp
<%@ page contentType = "text/html; charset = UTF-8" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>${message}</h2>
</body>
</html>
Aquí, hemos configurado el LOG4J para registrar detalles en la consola de Tomcat y en el archivo presente en & t; tomcat home → se registra como myapp.log.
Una vez que haya terminado de crear archivos fuente y de configuración, exporte su aplicación. Haga clic derecho en su aplicación, useExport → WAR File opción y guarda tu TestWeb.war archivo en la carpeta de aplicaciones web de Tomcat.
Ahora, inicie el servidor Tomcat y asegúrese de poder acceder a otras páginas web desde la carpeta webapps utilizando un navegador estándar. Prueba una URL -http://localhost:8080/TestWeb/hello y veremos la siguiente pantalla en el registro de Tomcat.