Spring MVC多视图页面示例图解

在这里, 我们将一个视图页面重定向到另一个视图页面。
让我们看一下Spring Web MVC框架的简单示例。步骤如下:

  • 在Maven的情况下加载spring jar文件或添加依赖项
  • 创建控制器类
  • 在web.xml文件中提供控制器的条目
  • 在单独的XML文件中定义bean
  • 创建其他视图组件
  • 启动服务器并部署项目
Spring MVC的目录结构
Spring MVC多视图页面示例图解

文章图片
1.将依赖项添加到pom.xml
< !-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc --> < dependency> < groupId> org.springframework< /groupId> < artifactId> spring-webmvc< /artifactId> < version> 5.1.1.RELEASE< /version> < /dependency> < !-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api --> < dependency> < groupId> javax.servlet< /groupId> < artifactId> servlet-api< /artifactId> < version> 3.0-alpha-1< /version> < /dependency>

2.创建请求页面
让我们创建一个包含链接的简单jsp页面。
index.jsp
< html> < body> < a href="http://www.srcmini.com/hello"> Click here...< /a> < /body> < /html>

3.创建控制器类
让我们创建一个返回JSP页面的控制器类。在这里, 我们通过带有@Requestmapping批注的特定名称来映射该类。
【Spring MVC多视图页面示例图解】HelloController.java
package com.srcmini; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; @Controllerpublic class HelloController {@RequestMapping("/hello") public String redirect() {return "viewpage"; } @RequestMapping("/helloagain")public String display(){ return "final"; }}

4.在web.xml文件中提供控制器的条目
web.xml
< ?xml version="1.0" encoding="UTF-8"?> < web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> < display-name> SpringMVC< /display-name> < servlet> < servlet-name> spring< /servlet-name> < servlet-class> org.springframework.web.servlet.DispatcherServlet< /servlet-class> < load-on-startup> 1< /load-on-startup> < /servlet> < servlet-mapping> < servlet-name> spring< /servlet-name> < url-pattern> /< /url-pattern> < /servlet-mapping> < /web-app>

5.在xml文件中定义bean
现在, 我们还为视图解析器提供了视图组件。
在这里, InternalResourceViewResolver类用于ViewResolver。
由controller + suffix页面返回的prefix + string将被视图组件调用。
此xml文件应位于WEB-INF目录内。
spring-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/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsd"> < !-- Provide support for component scanning --> < context:component-scan base-package="com.srcmini" /> < !--Provide support for conversion, formatting and validation --> < mvc:annotation-driven/> < !-- Define Spring MVC view resolver --> < bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> < property name="prefix" value="http://www.srcmini.com/WEB-INF/jsp/"> < /property> < property name="suffix" value="http://www.srcmini.com/.jsp"> < /property> < /bean> < /beans>

6.创建其他视图组件
viewpage.jsp
< html> < body> < a href="http://www.srcmini.com/helloagain"> srcmini Tutorials< /a> < /body> < /html>

final.jsp
< html> < body> < p> Welcome to Spring MVC Tutorial< /p> < /body> < /html>

输出
Spring MVC多视图页面示例图解

文章图片
Spring MVC多视图页面示例图解

文章图片
Spring MVC多视图页面示例图解

文章图片
下载此示例(使用Eclipse开发)

    推荐阅读