- @RequestMapping 映射请求注解
- SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些 URL 请求
- 在控制器的类定义及方法定义处都可标注 @RequestMapping
- 标记在类上:提供初步的请求映射信息。相对于 WEB 应用的根目录
- 标记在方法上:提供进一步的细分映射信息。相对于标记在类上的 URL。
- 若类上未标注 @RequestMapping,则方法处标记的 URL 相对于 WEB 应用的根目录
作用:DispatcherServlet 截获请求后,就通过控制器上 @RequestMapping 提供的映射信息确定请求所对应的处理方法。
- @ RequestMapping源码参考
package org.springframework.web.bind.annotation;
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Mapping
public @interface RequestMapping {
String[] value() default {};
RequestMethod[] method() default {};
String[] params() default {};
String[] headers() default {};
String[] consumes() default {};
String[] produces() default {};
}
- 实验代码
- 定义页面链接、控制器方法
<a href="springmvc/helloworld">test @RequestMapping</a>
@Controller //声明Bean对象,为一个控制器组件
@RequestMapping("/springmvc")
public class HelloWorldController {
/**
* 映射请求的名称:用于客户端请求;类似Struts2中action映射配置的,action名称
*1 使用@RequestMapping 注解来映射请求的 URL
*2 返回值会通过视图解析器解析为实际的物理视图,
对于 InternalResourceViewResolver 视图解析器,
* 会做如下的解析:
* 通过 p