SpringMVC笔记系列(2)——@RequestMapping请求映射物理视图解析

上一篇的例子介绍了如何构建一个springMVC的请求映射的方法。但是@RequestMapping不仅可以修饰控制器类的方法,还可以可以修饰控制器类本身,它对请求的影响是:请求url的分段。

还是看一个例子吧。

假如现在有一个请求页面index2.jsp。

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>RequestMapping Test</title>
</head>
<body>
<a href="c1/m1">c1/m1</a><br/>
<a href="c1/m2">c1/m2</a><br/>
<a href="c1/m3">c1/m3</a><br/>
</body>
</html>

另有3个响应页面robot_baymax1.jsp、robot_baymax2.jsp、robot_baymax3.jsp在webapp的views文件夹下。

SpringMVC笔记系列(2)——@RequestMapping请求映射物理视图解析


现在我们要做的就是用springMVC的DispatcherServlet来处理 请求页面的请求 到 响应页面的映射。

关于映射的详细过程请看上一篇。

springmvc.xml配置文件。(本文出自开源中国happyBKs的博客文章:http://my.oschina.net/u/1156339/blog/411861)

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

<!-- 配置自动扫描的包 -->
<context:component-scan base-package="com.happyBKs.springmvc.handlers"></context:component-scan>

<!-- 配置视图解析器:如何把handler方法 的返回值 解析为 实际的物理视图-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>


</beans>

重点来了,我重新构造一个控制器类,来处理这种多段的请求。

定义控制器类RobotHandler。

@RequestMapping除了修饰方法,还可以来修饰类

类定义处:提供初步的请求映射信息。相对于web应用的根目录

方法定义处:进一步提供细分的映射信息。相对于类定义处的URL。若类定义处没有标注@RequestMapping,则方法处的@RequestMapping直接对应于web应用的根目录。

这里做个罗列,可能看得更清楚:

请求:(网站域名+web应用名)web应用根目录+类定义处@RequestMapping+方法定义处@RequestMapping

映射到

物理视图:webapp根目录+springmvc.xml配置的prefix+ 控制器方法的返回值 +springmvc.xml配置的sufix


这里的话是

请求:http://localhost:8080/mymvc/c1/m1

映射到

物理视图webapp/views/robot_baymax1.jsp就通过控制器上的


映射过程是:DispatchServlet在截获请求后,@RequestMapping提供额映射信息确认请求所对应对的处理方法。

package com.happyBKs.springmvc.handlers;

import java.lang.annotation.Retention;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

/*
1.@RequestMapping除了修饰方法,还可以来修饰类
类定义处:提供初步的请求映射信息。相对于web应用的根目录
方法定义处:进一步提供细分的映射信息。相对于类定义处的URL。若类定义处没有标注@RequestMapping,则方法处的@RequestMapping直接对应于web应用的根目录

请求:(网站域名+web应用名)web应用根目录+类定义处@RequestMapping+方法定义处@RequestMapping
映射到
物理视图:webapp根目录+springmvc.xml配置的prefix+ 控制器方法的返回值 +springmvc.xml配置的sufix


这里的话是
请求:http://localhost:8080/mymvc/c1/m1
映射到
物理视图webapp/views/robot_baymax1.jsp就通过控制器上的


映射过程是:DispatchServlet在截获请求后,@RequestMapping提供额映射信息确认请求所对应对的处理方法。
*/
@RequestMapping("/c1")
@Controller
public class RobotHandler {
	
	@RequestMapping("/m1")
	String handle1()
	{
		return "robot_baymax1";
	}
	
	@RequestMapping("/m2")
	String handle2()
	{
		return "robot_baymax2";
	}
	
	
	@RequestMapping("/m3")
	String handle3()
	{
		return "robot_baymax3";
	}
}





你可能感兴趣的:(springMVC)