首页 > 代码库 > Spring MVC之RequestMapping

Spring MVC之RequestMapping

第一部分、概述

/**映射URL到控制器类或处理程序*/
@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Mapping
public @interface RequestMapping {

/**
* 指定映射名称
* 支持控制器和方法
* 同时支持控制器和方法时,使用"#"分隔
*/
String name() default "";

/**
* 路径映射
* 指定的地址可以是uri模板,别名为path,如:@RequestMapping("/foo"),@RequestMapping(path="/foo")
* 支持控制器和方法,当其用于控制器映射时,该控制器所有方法映射均继承本映射
*/
@AliasFor("path")
String[] value() default {};

/**
* 仅支持Servlet运行环境:路径映射URIs(如:"/myPath.do")
* 支持Ant风格的路径模式
* 在控制器的方法这一层级,支持相对路径(如:"edit.do")
* 在控制器层级,可包含占位符(如:/${connect})
* 当其用于控制器映射时,该控制器所有方法映射均继承本映射
*/
@AliasFor("value")
String[] path() default {};

/**
* HTTP请求方式(谓词类型):GET, POST, HEAD, OPTIONS, PUT, PATCH, DELETE, TRACE.
* 支持控制器和方法,当其用于控制器映射时,该控制器所有方法映射均继承本映射
*/
RequestMethod[] method() default {};

/**
* 请求参数限定:限制客户端发送的请求参数为某些特定值或不为某些值。
* 使用方式:"myParam=myValue" 、"myParam!=myValue"
* 支持控制器和方法,当其用于控制器映射时,该控制器所有方法映射均继承本映射
*/
String[] params() default {};

/**
* 请求头部
* 使用方式:"My-Header=myValue" 、"My-Header!=myValue"
* 如:RequestMapping(value = "http://www.mamicode.com/something", headers = "content-type=text/*")
* 支持控制器和方法,当其用于控制器映射时,该控制器所有方法映射均继承本映射
*/
String[] headers() default {};

/**
* 请求媒体类型(消耗型媒体类型)(text/html、text/plain、application/json;charset=UTF-8、application/octet-stream等等)
* 如:consumes = "text/plain"、consumes = {"text/plain", "application/*"}
* 支持控制器和方法,当其用于控制器映射时,该控制器所有方法映射均重写本映射
*/
String[] consumes() default {};

/**
* 响应媒体类型(生产型媒体类型)(text/html、text/plain、application/json;charset=UTF-8、application/octet-stream等等)
* 如:consumes = "text/plain"、consumes = {"text/plain", "application/*"}
* 支持控制器和方法,当其用于控制器映射时,该控制器所有方法映射均重写本映射
*/
String[] produces() default {};

}


第二部分:路径相关

1、只注解方法

默认为根路径

访问路径:http://localhost:8080/auth/index.do

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16*/@Controllerpublic class SsoController {  //@Autowired  //private AuthService authService;  @RequestMapping(value = "http://www.mamicode.com/index.do", method = RequestMethod.GET)  public ModelAndView index() {    ModelAndView mv = new ModelAndView("login");    return mv;  }}

  

2、同时注解控制器和方法

用根路径和方法路径叠加

访问路径:http://localhost:8080/auth/sso/index.do

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16*/@Controller@RequestMapping("/sso")public class SsoController {    //@Autowired    //private AuthService authService;    @RequestMapping(value = "http://www.mamicode.com/index.do", method = RequestMethod.GET)    public ModelAndView index() {        ModelAndView mv = new ModelAndView("login");        return mv;    }}    

  

3、value为空

控制器上@RequestMapping的value为空 或者 没有@RequestMapping修饰,使用站点根路径
方法上@RequestMapping的value为空,使用控制器根路径
以上前提:web.xml上放行默认路径,<url-pattern>/</url-pattern>

访问路径:http://localhost:8080/auth/sso

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16*/@Controllerpublic class SsoController {    //@Autowired    //private AuthService authService;    @RequestMapping    public ModelAndView index() {        ModelAndView mv = new ModelAndView("login");        return mv;    }}        

  

4、路径变量占位符
使用@PathVariable 注释方法参数的值绑定到一个URI模板变量

访问路径:http://localhost:8080/auth/sso/index/1

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16*/@Controller@RequestMapping("/sso")public class SsoController {    //@Autowired    //private AuthService authService;    @RequestMapping("/index/{id}")    public ModelAndView index(@PathVariable int id) {        ModelAndView mv = new ModelAndView("login");        return mv;}}

  

4.1)路径模板可以使用正则表达式
  如:@RequestMapping(value="http://www.mamicode.com/index/{id://d{3}}/{name:[a-z]{3}}")
  对应访问路径:http://localhost:8080/auth/sso/index/123/ass

4.2)矩阵变量@MatrixVariable
  矩阵变量可以出现在任何路径段,每个矩阵变量用“;”分隔
  暂时未用到,用到的时候再说吧,个人不倾向于在地址中传递这么复杂的东西

4.3)Ant风格路径模式
  如/myPath/*.do,/myPath/*/auth/{uid}


第三部分:谓词类型
用于约束请求类型,包含:GET, POST, HEAD, OPTIONS, PUT, PATCH, DELETE, TRACE,支持控制器和方法,当其用于控制器映射时,该控制器所有方法映射均继承本映射。一般标识方法。

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16*/@Controller@RequestMapping("/sso")public class SsoController {    //@Autowired    //private AuthService authService;    @RequestMapping(value="http://www.mamicode.com/index.do",method= RequestMethod.POST,RequestMethod.GET})    public ModelAndView index(@PathVariable int id,@PathVariable String name) {        ModelAndView mv = new ModelAndView("login");        return mv;    }}

  

第四部分:参数限定
映射请求的参数,限制客户端发送的请求参数为某些特定值或不为某些值。
访问路径:http://localhost:8080/auth/sso/index.do?id=1&name=bbb
http://localhost:8080/auth/sso/index.do?id=1&name=aaa

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16*/@Controller@RequestMapping("/sso")public class SsoController {    //@Autowired    //private AuthService authService;    @RequestMapping(value="http://www.mamicode.com/index.do"        ,method={RequestMethod.POST,RequestMethod.GET}        ,params={"id=1","name!=aaa"})    public ModelAndView index() {        ModelAndView mv = new ModelAndView("login");        return mv;    }}

  

第五部分:头部限定
映射请求的头部,限制客户端发送的请求头部信息必须包含某些值或不为某些值。
如:

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16*/@Controller@RequestMapping("/sso")public class SsoController {    //@Autowired    //private AuthService authService;    @RequestMapping(value="http://www.mamicode.com/index.do"        ,method={RequestMethod.POST,RequestMethod.GET}        ,params={"id=1","name!=aaa"}        ,headers="Host=localhost:8080"    )    public ModelAndView index() {        ModelAndView mv = new ModelAndView("login");        return mv;    }}

  

第六部分:Content-Type限定
请求:@RequestMapping(value = "http://www.mamicode.com/action8",consumes="text/plain")
响应:@RequestMapping(value = "http://www.mamicode.com/action8",consumes="text/html")

如:

/*** @功能 权限控制器* @作者 Davee.Yuan* @日期 2017-01-16* @说明 http://localhost:8080/auth/index*/@Controller@RequestMapping("/sso")public class SsoController {    //@Autowired    //private AuthService authService;    @RequestMapping(value="http://www.mamicode.com/index.do"        ,method={RequestMethod.POST,RequestMethod.GET}        ,params={"id=1","name!=aaa"}        ,headers="Host=localhost:8080"       ,produces="text/html"    )    public ModelAndView index() {        ModelAndView mv = new ModelAndView("login");        return mv;    }}

  

第七部分:其他
您准备用么?

 

Spring MVC之RequestMapping