Spring - Visão geral do MVC Framework

A estrutura Spring Web MVC fornece uma arquitetura de controlador de visualização de modelo e componentes prontos que podem ser usados ​​para desenvolver aplicativos da web flexíveis e fracamente acoplados. O padrão MVC resulta na separação dos diferentes aspectos do aplicativo (lógica de entrada, lógica de negócios e lógica de IU), enquanto fornece um acoplamento fraco entre esses elementos.

  • o Model encapsula os dados do aplicativo e, em geral, eles consistirão em POJO.

  • o View é responsável por renderizar os dados do modelo e, em geral, gera HTML saída que o navegador do cliente pode interpretar.

  • o Controller é responsável pelo processamento User Requests e Building Appropriate Model e passa para a visualização para renderização.

O DispatcherServlet

A estrutura do Spring Web model-view-controller (MVC) é projetada em torno de um DispatcherServlet que trata todas as solicitações e respostas HTTP. O fluxo de trabalho de processamento de solicitação do Spring Web MVC DispatcherServlet é mostrado na ilustração a seguir.

A seguir está a sequência de eventos correspondentes a uma solicitação HTTP de entrada para DispatcherServlet -

  • Depois de receber uma solicitação HTTP, o DispatcherServlet consulta o HandlerMapping para chamar o Controlador apropriado.

  • O Controlador recebe a solicitação e chama os métodos de serviço apropriados com base nas GET ou POST method. O método de serviço configurará os dados do modelo com base na lógica de negócios definida e retorna o nome da visualização para o DispatcherServlet.

  • O DispatcherServlet receberá ajuda de ViewResolver para obter a visão definida para a solicitação.

  • Depois que a visualização é finalizada, o DispatcherServlet passa os dados do modelo para a visualização, que é finalmente renderizada nos navegadores.

Todos os componentes mencionados acima, ou seja, HandlerMapping, Controller e ViewResolver são partes do WebApplicationContext, que é uma extensão da planície ApplicationContext com alguns recursos extras necessários para aplicativos da web.

Configuração Requerida

Precisamos mapear as solicitações que você deseja que o DispatcherServlet trate, usando um mapeamento de URL no web.xmlArquivo. A seguir está um exemplo para mostrar declaração e mapeamento 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>

o web.xml arquivo será mantido no WebContent/WEB-INFdiretório do seu aplicativo da web. Após a inicialização doHelloWeb DispatcherServlet, a estrutura tentará carregar o contexto do aplicativo a partir de um arquivo denominado [servlet-name]-servlet.xmllocalizado no diretório WebContent / WEB-INF do aplicativo. Neste caso, nosso arquivo seráHelloWeb-servlet.xml.

A seguir, o <servlet-mapping>tag indica quais URLs serão tratados por qual DispatcherServlet. Aqui, todas as solicitações HTTP que terminam com .jsp serão tratadas peloHelloWeb DispatcherServlet.

Se você não quiser usar o nome de arquivo padrão como [servlet-name]-servlet.xml e o local padrão como WebContent / WEB-INF, você pode personalizar esse nome de arquivo e local adicionando o ouvinte de servlet ContextLoaderListener em seu arquivo web.xml da seguinte maneira -

<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>

Agora, vamos verificar a configuração necessária para HelloWeb-servlet.xml , colocado no diretório WebContent / WEB-INF de seu aplicativo da 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 seguir estão alguns pontos importantes sobre HelloWeb-servlet.xml arquivo -

  • o [servlet-name]-servlet.xml O arquivo será usado para criar os beans definidos, substituindo as definições de quaisquer beans definidos com o mesmo nome no escopo global.

  • o <context:component-scan...> tag será usada para ativar o recurso de varredura de anotação Spring MVC, que permite fazer uso de anotações como @Controller e @RequestMappingetc.

  • o InternalResourceViewResolverterá regras definidas para resolver os nomes das visualizações. De acordo com a regra definida acima, uma visão lógica chamadahello é delegado a uma implementação de visão localizada em /WEB-INF/jsp/hello.jsp.

Vamos agora entender como criar os componentes reais, ou seja, Controlador, Modelo e Visualização.

Definindo um controlador

O DispatcherServlet delega a solicitação aos controladores para executar a funcionalidade específica a ele. o@Controllera anotação indica que uma determinada classe desempenha o papel de um controlador. o@RequestMapping a anotação é usada para mapear um URL para uma classe inteira ou um método de manipulador específico.

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

}

o @Controllera anotação define a classe como um controlador Spring MVC. Aqui, o primeiro uso de@RequestMapping indica que todos os métodos de tratamento neste controlador são relativos ao /hello caminho.

A próxima anotação @RequestMapping (method = RequestMethod.GET) é usado para declarar o printHello()método como o método de serviço padrão do controlador para lidar com a solicitação HTTP GET. Podemos definir outro método para lidar com qualquer solicitação POST na mesma URL.

Também podemos escrever o controlador acima em outra forma, onde podemos adicionar atributos adicionais no @RequestMapping da seguinte maneira -

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

}

o value atributo indica a URL para a qual o método do manipulador é mapeado e o method atributo define o método de serviço para lidar com a solicitação HTTP GET.

A seguir estão alguns pontos importantes a serem observados em relação ao controlador definido acima -

  • Você definirá a lógica de negócios necessária dentro de um método de serviço. Você pode chamar outro método dentro deste método de acordo com o requisito.

  • Com base na lógica de negócios definida, você criará um modelo dentro deste método. Você pode definir diferentes atributos do modelo e esses atributos serão acessados ​​pela vista para apresentar o resultado. Este exemplo cria um modelo com seu atributo "mensagem".

  • Um método de serviço definido pode retornar um String, que contém o nome do viewa ser usado para renderizar o modelo. Este exemplo retorna "hello" como o nome da visualização lógica.

Criação de visualizações JSP

Spring MVC oferece suporte a muitos tipos de visualizações para diferentes tecnologias de apresentação. Esses incluem -JSPs, HTML, PDF, Excel Worksheets, XML, Velocity Templates, XSLT, JSON, Atom e RSS feeds, JasperReports, etc. No entanto, os mais comuns são os modelos JSP escritos com JSTL. Então, vamos escrever uma visão simples de olá em /WEB-INF/hello/hello.jsp -

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

Aqui ${message}Aqui está o atributo, que configuramos dentro do Controlador. Você pode ter vários atributos a serem exibidos dentro de sua visualização.