注解 @RequestMapping

简介

@RequestMapping 是一个注解,用来标识 http 请求地址与 Controller 类或方法之间的映射。

1.用于方法上,该方法直接响应请求

请求:http:localhost:8080/xxx/haha

2.用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。

请求:http:localhost:8080/xxx/action/haha

 

 

该注解有6个属性

我们可以将它们分为3类

1.value  method

  • value : 指定请求的实际地址,指定的地址可以是URI Template 模式;(如果值配置该属性,属性名可以省略不写)
  • method:  限定请求的method类型, GET、POST、PUT、DELETE等;例如: method=RequestMethod.GET 只接受get                请求,不设置的情况下默认接受任意请求   

2.   params  headers

  • params: 指定request中必须包含某些参数值是,才让该方法处理。

headers: 指定request中必须包含某些指定的header值,才能让该方法处理请求。

3.  consumes   produces  (这两个属性其实没啥卵用,用不到)

  • consumes: 指定处理请求的提交内容类型(Content-Type),例如application/json, text/html;
  • produces:    指定返回的内容类型,仅当request请求头中的(Accept)类型中包含该指定类型才返回;

 

 

value   method 演示:

 

params   headers演示:

 

 

ANT分格的URL

另外注解@RequestMapping 有一种ANT风格的URL写法,该URL地址中可以写模糊的通配符  (三种通配符)

  1.   ?    :  能够替代任意一个字符  (某些特殊的字符不能替代: /  #)
  2.   *     :  能够替代任意多个字符 或 一层路径
  3.   **   :  能替代多层路径

注意:当精确与模糊都匹配时,精确路径优先

 

精确路径匹配:

@RequestMapping("/antURL01")  //精确的url写法  
public String antURL01()

?替代一个任意字符  例如: antURL03, antURL0a

@RequestMapping("/antURL0?") // antURL0   后面匹配任意一个字符  
public String antURL02()

*  替代多个任意字符或者一层路径 

 多个任意字符匹配   例如: antURL024343  , antURL0afa2343

//模糊匹配:*
@RequestMapping("/antURL0*") // antURL0     后面匹配多个字符  

一层路径匹配  例如:antURL0/fsfs   , antURL0/4343sfs

@RequestMapping("/antURL0/*") // antURL0     后面匹配一层路径  
public String antURL04()

** 匹配多层路径   例如:  antURL0/sf24/43   ,antURL0/wer/1323/f3f/123tr

//模糊匹配   **
@RequestMapping("/antURL0/**") // antURL0     后面匹配多层路径  
public String antURL05()

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值