Среда Spring Web MVC предоставляет архитектуру модель-представление-контроллер и готовые компоненты, которые можно использовать для разработки гибких и слабо связанных веб-приложений. Шаблон MVC приводит к разделению различных аспектов приложения (логика ввода, бизнес-логика и логика пользовательского интерфейса), обеспечивая при этом слабую связь между этими элементами.
-
Модель инкапсулирует данные приложения и, как правило, они состоят из POJO .
-
Представление отвечает за визуализацию данных модели и, в общем, генерирует вывод HTML, который может интерпретировать браузер клиента.
-
Контроллер отвечает за обработку пользовательских запросов и построение соответствующей модели и передает ее в представление для визуализации.
Модель инкапсулирует данные приложения и, как правило, они состоят из POJO .
Представление отвечает за визуализацию данных модели и, в общем, генерирует вывод HTML, который может интерпретировать браузер клиента.
Контроллер отвечает за обработку пользовательских запросов и построение соответствующей модели и передает ее в представление для визуализации.
ДиспетчерСервлет
Среда Spring Web Model-View-Controller (MVC) разработана на основе DispatcherServlet, который обрабатывает все HTTP-запросы и ответы. Рабочий процесс обработки запросов Spring Web MVC DispatcherServlet показан на следующем рисунке.
Ниже приведена последовательность событий, соответствующая входящему HTTP-запросу в DispatcherServlet.
-
После получения HTTP-запроса DispatcherServlet обращается к HandlerMapping для вызова соответствующего контроллера.
-
Контроллер принимает запрос и вызывает соответствующие методы обслуживания на основе используемого метода GET или POST . Сервисный метод устанавливает данные модели на основе определенной бизнес-логики и возвращает имя представления в DispatcherServlet.
-
DispatcherServlet примет помощь от ViewResolver, чтобы подобрать определенное представление для запроса.
-
После того, как представление завершено, DispatcherServlet передает данные модели представлению, которое, наконец, отображается, в браузерах.
После получения HTTP-запроса DispatcherServlet обращается к HandlerMapping для вызова соответствующего контроллера.
Контроллер принимает запрос и вызывает соответствующие методы обслуживания на основе используемого метода GET или POST . Сервисный метод устанавливает данные модели на основе определенной бизнес-логики и возвращает имя представления в DispatcherServlet.
DispatcherServlet примет помощь от ViewResolver, чтобы подобрать определенное представление для запроса.
После того, как представление завершено, DispatcherServlet передает данные модели представлению, которое, наконец, отображается, в браузерах.
Все вышеупомянутые компоненты, то есть HandlerMapping, Controller и ViewResolver, являются частями WebApplicationContext , который является расширением простого ApplicationContext с некоторыми дополнительными функциями, необходимыми для веб-приложений.
Требуемая конфигурация
Нам нужно отобразить запросы, которые вы хотите обработать DispatcherServlet, используя сопоставление URL-адресов в файле web.xml . Ниже приведен пример демонстрации объявления и сопоставления для HelloWeb 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>
Файл web.xml будет храниться в каталоге WebContent / WEB-INF вашего веб-приложения. После инициализации HelloWeb DispatcherServlet платформа попытается загрузить контекст приложения из файла с именем [servlet-name] -servlet.xml, расположенного в каталоге приложения WebContent / WEB-INF. В этом случае наш файл будет HelloWeb-servlet.xml .
Затем тег <servlet-mapping> указывает, какие URL будут обрабатываться каким DispatcherServlet. Здесь все HTTP-запросы, заканчивающиеся на .jsp, будут обрабатываться HelloWeb DispatcherServlet.
Если вы не хотите использовать имя файла по умолчанию как [servlet-name] -servlet.xml и расположение по умолчанию как WebContent / WEB-INF, вы можете настроить это имя файла и местоположение, добавив прослушиватель сервлета ContextLoaderListener в свой файл web.xml. файл следующим образом —
<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>
Теперь давайте проверим необходимую конфигурацию файла HelloWeb-servlet.xml , который находится в каталоге WebContent / WEB-INF вашего веб-приложения.
<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>
Ниже приведены некоторые важные моменты, касающиеся файла HelloWeb-servlet.xml.
-
Файл [servlet-name] -servlet.xml будет использоваться для создания определенных bean-компонентов, переопределяя определения любых bean-компонентов, определенных с таким же именем в глобальной области видимости.
-
Тег <context: component-scan …> будет использоваться для активации возможности сканирования аннотаций Spring MVC, которая позволяет использовать аннотации, такие как @Controller, @RequestMapping и т. Д.
-
InternalResourceViewResolver будет иметь правила, определенные для разрешения имен представлений. В соответствии с определенным выше правилом логическое представление с именем hello делегируется реализации представления, расположенной в /WEB-INF/jsp/hello.jsp .
Файл [servlet-name] -servlet.xml будет использоваться для создания определенных bean-компонентов, переопределяя определения любых bean-компонентов, определенных с таким же именем в глобальной области видимости.
Тег <context: component-scan …> будет использоваться для активации возможности сканирования аннотаций Spring MVC, которая позволяет использовать аннотации, такие как @Controller, @RequestMapping и т. Д.
InternalResourceViewResolver будет иметь правила, определенные для разрешения имен представлений. В соответствии с определенным выше правилом логическое представление с именем hello делегируется реализации представления, расположенной в /WEB-INF/jsp/hello.jsp .
Давайте теперь поймем, как создавать фактические компоненты, т.е. Контроллер, Модель и Представление.
Определение контроллера
DispatcherServlet делегирует запрос контроллерам для выполнения специфической для него функциональности. Аннотация @Controller указывает, что определенный класс выполняет роль контроллера. Аннотация @RequestMapping используется для сопоставления URL либо с целым классом, либо с конкретным методом-обработчиком.
@Controller @RequestMapping("/hello") public class HelloController{ @RequestMapping(method = RequestMethod.GET) public String printHello(ModelMap model) { model.addAttribute("message", "Hello Spring MVC Framework!"); return "hello"; } }
Аннотация @Controller определяет класс как контроллер Spring MVC. Здесь первое использование @RequestMapping указывает, что все методы обработки на этом контроллере относятся к пути / hello .
Следующая аннотация @RequestMapping (method = RequestMethod.GET) используется для объявления метода printHello () в качестве метода службы контроллера по умолчанию для обработки HTTP-запроса GET. Мы можем определить другой метод для обработки любого запроса POST по тому же URL.
Мы также можем написать приведенный выше контроллер в другой форме, где мы можем добавить дополнительные атрибуты в @RequestMapping следующим образом:
@Controller public class HelloController{ @RequestMapping(value = "/hello", method = RequestMethod.GET) public String printHello(ModelMap model) { model.addAttribute("message", "Hello Spring MVC Framework!"); return "hello"; } }
Атрибут value указывает URL-адрес, с которым сопоставляется метод обработчика, а атрибут метода определяет метод службы для обработки запроса HTTP GET.
Ниже приведены некоторые важные моменты, касающиеся контроллера, определенного выше:
-
Вы определите необходимую бизнес-логику внутри метода службы. Вы можете вызвать другой метод внутри этого метода согласно требованию.
-
На основе определенной бизнес-логики вы создадите модель в этом методе. Вы можете установить различные атрибуты модели, и эти атрибуты будут доступны представлению для представления результата. В этом примере создается модель с атрибутом «сообщение».
-
Определенный метод службы может возвращать строку, которая содержит имя представления, которое будет использоваться для визуализации модели. В этом примере возвращается «привет» в качестве имени логического представления.
Вы определите необходимую бизнес-логику внутри метода службы. Вы можете вызвать другой метод внутри этого метода согласно требованию.
На основе определенной бизнес-логики вы создадите модель в этом методе. Вы можете установить различные атрибуты модели, и эти атрибуты будут доступны представлению для представления результата. В этом примере создается модель с атрибутом «сообщение».
Определенный метод службы может возвращать строку, которая содержит имя представления, которое будет использоваться для визуализации модели. В этом примере возвращается «привет» в качестве имени логического представления.
Создание JSP-видов
Spring MVC поддерживает много типов представлений для различных технологий представления. К ним относятся — JSP, HTML, PDF, рабочие листы Excel, XML, шаблоны скорости, XSLT, JSON, Atom и RSS- каналы, JasperReports и т. Д. Однако наиболее распространенными являются шаблоны JSP, написанные с использованием JSTL. Итак, давайте напишем простое приветствие в /WEB-INF/hello/hello.jsp —
<html> <head> <title>Hello Spring MVC</title> </head> <body> <h2>${message}</h2> </body> </html>
Здесь $ {message} Вот атрибут, который мы настроили внутри Контроллера. Вы можете иметь несколько атрибутов для отображения внутри вашего представления.