ResourceBundleViewResolver используется для разрешения имен представлений с использованием компонентов представления, определенных в файле свойств. В следующем примере показано, как использовать ResourceBundleViewResolver с помощью Spring Web MVC Framework.
TestWeb-servlet.xml
<bean class = "org.springframework.web.servlet.view.ResourceBundleViewResolver"> <property name = "basename" value = "views" /> </bean>
Здесь базовое имя относится к имени пакета ресурсов, который содержит представления. Имя пакета ресурсов по умолчанию — views.properties , которое можно переопределить с помощью свойства basename.
views.properties
hello.(class) = org.springframework.web.servlet.view.JstlView hello.url = /WEB-INF/jsp/hello.jsp
Например, используя вышеуказанную конфигурацию, если URI —
-
/ hello запрашивается, DispatcherServlet перенаправляет запрос в hello.jsp, определенный bean hello в views.properties.
-
Здесь «привет» — это имя представления, которое должно быть сопоставлено. Принимая во внимание, что класс относится к типу представления, а URL — к местоположению представления.
/ hello запрашивается, DispatcherServlet перенаправляет запрос в hello.jsp, определенный bean hello в views.properties.
Здесь «привет» — это имя представления, которое должно быть сопоставлено. Принимая во внимание, что класс относится к типу представления, а URL — к местоположению представления.
Для начала давайте наладим работающую среду Eclipse IDE и рассмотрим следующие шаги для разработки веб-приложения на основе динамических форм с использованием Spring Web Framework.
шаг | Описание |
---|---|
1 | Создайте проект с именем TestWeb в пакете com.tutorialspoint, как описано в главе Spring MVC — Hello World. |
2 | Создайте Java-класс HelloController в com.tutorialspointpackage. |
3 | Создайте файл представления hello.jsp в подпапке jsp. |
4 | Создайте файл свойств views.properties в папке src. |
5 | Загрузите библиотеку JSTL jstl.jar . Поместите это в свой CLASSPATH. |
6 | Последний шаг — создание содержимого исходного файла и файлов конфигурации и экспорт приложения, как описано ниже. |
HelloController.java
package com.tutorialspoint; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.ui.ModelMap; @Controller @RequestMapping("/hello") public class HelloController{ @RequestMapping(method = RequestMethod.GET) public String printHello(ModelMap model) { model.addAttribute("message", "Hello Spring MVC Framework!"); return "hello"; } }
TestWeb-servlet.xml
<beans xmlns = "http://www.springframework.org/schema/beans" xmlns:context = "http://www.springframework.org/schema/context" xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation = " http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd"> <context:component-scan base-package = "com.tutorialspoint" /> <bean class = "org.springframework.web.servlet.view.ResourceBundleViewResolver"> <property name = "basename" value = "views" /> </bean> </beans>
views.properties
hello.(class) = org.springframework.web.servlet.view.JstlView hello.url = /WEB-INF/jsp/hello.jsp
hello.jsp
<%@ page contentType="text/html; charset=UTF-8" %> <html> <head> <title>Hello World</title> </head> <body> <h2>${message}</h2> </body> </html>
Когда вы закончите создавать исходные файлы и файлы конфигурации, экспортируйте ваше приложение. Щелкните правой кнопкой мыши свое приложение, выберите « Экспорт» → «Файл WAR» и сохраните файл HelloWeb.war в папке веб-приложений Tomcat.
Теперь запустите сервер Tomcat и убедитесь, что вы можете получить доступ к другим веб-страницам из папки веб-приложений с помощью стандартного браузера. Попробуйте получить доступ к URL-адресу — http: // localhost: 8080 / HelloWeb / hello, и если с веб-приложением Spring все в порядке, мы увидим следующий экран.