📜  Spring MVC-多个解析器映射示例(1)

📅  最后修改于: 2023-12-03 15:20:13.328000             🧑  作者: Mango

Spring MVC-多个解析器映射示例

Spring MVC 是一个框架,用于开发基于 Java 的 web 应用程序。它提供了强大的控制器层、模型层和视图层的支持,使得开发者能够快速地构建并部署 web 应用程序。

在 Spring MVC 中,解析器映射器用于将请求的 URL 映射到相应的控制器方法上。通常情况下,我们会使用默认的解析器映射器,但是在某些情况下,我们需要使用多个解析器映射器。

接下来,我们将给出一个基于 Spring MVC 的多个解析器映射示例。

示例说明

我们将创建一个简单的 web 应用程序,该应用程序包含两个控制器方法。这两个方法分别接受名为 "id" 的参数,并分别返回 "student" 和 "teacher" 的信息。

我们将创建两个解析器映射器:一个用于将请求的 URL 映射到 "students" 控制器方法上,另一个用于将请求的 URL 映射到 "teachers" 控制器方法上。

在这个示例中,我们将使用以下技术:

  • Spring MVC 框架
  • Maven 构建工具
  • Tomcat 容器
步骤
步骤一:创建 Maven 项目

通过以下命令在命令行界面中创建一个基于 Maven 的 Spring MVC 项目:

mvn archetype:generate -DgroupId=com.example -DartifactId=spring-mvc-demo -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false

该命令将创建一个名为 "spring-mvc-demo" 的 Maven 项目。接下来,我们需要在 pom.xml 文件中添加 Spring MVC 等必要的依赖项。

<dependencies>
	<!-- Spring MVC -->
	<dependency>
		<groupId>org.springframework</groupId>
		<artifactId>spring-webmvc</artifactId>
		<version>5.3.9</version>
	</dependency>

	<!-- JSTL -->
	<dependency>
		<groupId>javax.servlet</groupId>
		<artifactId>jstl</artifactId>
		<version>1.2</version>
	</dependency>
	
	<!-- Servlet API -->
	<dependency>
		<groupId>javax.servlet</groupId>
		<artifactId>servlet-api</artifactId>
		<version>3.0.1</version>
		<scope>provided</scope>
	</dependency>
</dependencies>
步骤二:创建控制器

接下来,我们需要创建两个控制器方法:一个用于处理 "students" 请求,另一个用于处理 "teachers" 请求。

@Controller
public class DemoController {

    @RequestMapping("/students")
    public ModelAndView getStudent(HttpServletRequest request, HttpServletResponse response) {
        ModelAndView mav = new ModelAndView("show");

        String id = request.getParameter("id");
        mav.addObject("message", "This is student " + id);

        return mav;
    }

    @RequestMapping("/teachers")
    public ModelAndView getTeacher(HttpServletRequest request, HttpServletResponse response) {
        ModelAndView mav = new ModelAndView("show");

        String id = request.getParameter("id");
        mav.addObject("message", "This is teacher " + id);

        return mav;
    }

}

在这两个控制器方法中,我们使用 @RequestMapping 注解指定了请求 URL,并提供了一个 ModelAndView 引用类型的返回值。

步骤三:配置 Spring MVC

在 web.xml 文件中添加以下配置:

<servlet>
	<servlet-name>spring</servlet-name>
	<servlet-class>
		org.springframework.web.servlet.DispatcherServlet
	</servlet-class>
	<init-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>/WEB-INF/spring-mvc-demo-servlet.xml</param-value>
	</init-param>
	<load-on-startup>1</load-on-startup>
</servlet>

<servlet-mapping>
	<servlet-name>spring</servlet-name>
	<url-pattern>/</url-pattern>
</servlet-mapping>

这将使用 Spring 的 DispatcherServlet 类来处理所有的请求,并将其映射到相应的控制器方法上。

然后,在 /WEB-INF 目录中创建 spring-mvc-demo-servlet.xml 文件,添加以下配置:

<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.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc.xsd">

    <!-- 当前处理器映射器 -->
    <bean id="defaultHandlerMapping"
        class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>

    <!-- 学生处理器映射器 -->
    <bean id="studentHandlerMapping"
        class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
        <property name="order" value="1"/>
        <property name="mappings">
            <props>
                <prop key="/students">demoController</prop>
                <prop key="/students/*">demoController</prop>
            </props>
        </property>
    </bean>

    <!-- 教师处理器映射器 -->
    <bean id="teacherHandlerMapping"
        class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
        <property name="order" value="2"/>
        <property name="mappings">
            <props>
                <prop key="/teachers">demoController</prop>
                <prop key="/teachers/*">demoController</prop>
            </props>
        </property>
    </bean>

    <!-- DemoController -->
    <bean id="demoController" class="com.example.controller.DemoController"/>

    <!-- 视图解析器 -->
    <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="prefix" value="/WEB-INF/views/"/>
        <property name="suffix" value=".jsp"/>
    </bean>

    <mvc:annotation-driven/>

    <context:component-scan base-package="com.example.controller"/>

</beans>

这个配置文件中,我们首先定义了三个处理器映射器:一个默认的 BeanNameUrlHandlerMapping、一个用于处理 "students" 请求的 SimpleUrlHandlerMapping 和一个用于处理 "teachers" 请求的 SimpleUrlHandlerMapping。

然后,我们定义了 DemoController 类,并将其注入到了两个 SimpleUrlHandlerMapping 中。

最后,我们使用 InternalResourceViewResolver 类来设置 JSP 视图的前缀和后缀。

步骤四:创建 JSP 视图

在 /WEB-INF/views 目录中,创建名为 "show.jsp" 的 JSP 视图文件,该文件将显示从控制器方法返回的消息。

<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8" %>
<!DOCTYPE html>
<html>
<head>
	<meta charset="UTF-8"/>
	<title>Spring MVC Demo</title>
</head>
<body>
	<h1>${message}</h1>
</body>
</html>
步骤五:启动应用程序

执行以下命令,启动 Tomcat 容器:

mvn tomcat7:run

在浏览器中访问以下 URL:

http://localhost:8080/spring-mvc-demo/students?id=123

此时应该会看到一个消息,显示为 "This is student 123"。再访问以下 URL:

http://localhost:8080/spring-mvc-demo/teachers?id=456

此时应该会看到另一个消息,显示为 "This is teacher 456"。

总结

在这个示例中,我们介绍了如何使用 Spring MVC 创建一个支持多个解析器映射的基于 Java 的 web 应用程序。

通过解析器映射器和控制器,我们能够轻松地将请求映射到相应的控制器方法上,并返回所需的结果。