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 = "/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
*/
@Controller
public class SsoController {

  //@Autowired
  //private AuthService authService;

  @RequestMapping(value = "/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 = "/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
*/
@Controller
public 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="/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="/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="/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="/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 = "/action8",consumes="text/plain")
响应:@RequestMapping(value = "/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="/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;
    }
}

  

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

 

posted @ 2017-01-16 13:12  登峰观月  阅读(834)  评论(0编辑  收藏  举报