基本注解详解@RequestMapping,@GetMapping

基本注解详解@RequestMapping,@GetMapping

1. @RequestMapping注解

@RequestMapping注解是一个用来处理请求地址映射的注解,可用于映射一个请求或一个方法,可以用在类或方法上。

  1. @RequestMapping注解可以标注的位置
    • 标注在方法上

      用于方法上,表示在类的父路径下追加方法上注解中的地址将会访问到
      该方法

    • 标注在类和方法上

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

  2. @RequestMapping的属性

1.1@RequestMapping的value属性

@RequestMapping 的 value 属性必须设值;
@RequestMapping 的 value 属性是通过当前请求的请求地址来匹配请求;
从上面的源码中可以看到value属性是一个字符串类型的数组,因此说明可以将多个请求映射到一个方法上,只需要给 value 来指定一个包含多个路径的数组。

设置value的属性的值

@Controller
public class RequestMappingController {

    @RequestMapping(value = {"/testRequest","/test"})
    public String testRequest(){
        return "success";
    }
}

1.2 @RequestMapping的method属性*
  • @RequestMapping的method属性是通过当前请求的请求方式来匹配请求;
  • 浏览器向服务器发送请求,请求方式有很多GET、HEAD、POST、PUT、PATCH、DELETE、OPTIONS、TRACE。可以使用 method 属性来约束请求方式。

设置请求方式为get:

@Controller
public class RequestMappingController {

    @RequestMapping(value = "/testRequest",method = RequestMethod.GET)
    public String testRequest(){
        return "success";
    }
}

如果以post方式请求

映射方法中明确要求请求方式为get,所以post方式不被允许,只有修改为get,才能够请求成功,如果要想两种方式都支持,只需在@RequestMapping注解的method属性中添加另一种方式即可,中间用英文逗号隔开。

扩展:

@GetMapping:处理get方式请求的映射

@PostMapping:处理post方式请求的映射

@PutMapping:处理put方式请求的映射

@DeleteMapping:处理delete方式请求的映射

@GetMapping就相当于@RequestMapping(method=RequestMethod.GET),它会将get映射到特定的方法上。

使用方式:@GetMapping(value="/testRequest")

1.3@RequestMapping的params属性

@RequestMapping的params属性是通过当前请求的请求参数来匹配请求;
@RequestMapping的params属性是一个字符串类型的数组,可以通过下面四种表达是来设置匹配关系

“param”:要求请求映射的请求必须为包含 param的请求参数
“!param”:要求请求映射的请求是不能包含param的请求参数
“param=value”:要求请求映射的请求必须包含 param 的请求参数,且 param 参数的值必须为 value
“param!=value”: 要求请求映射的请求是必须包含 param 的请求参数,其值不能为 value。

设置params的属性值为username:

@RequestMapping(value = "/test",params = "username")
    public String test(){
        return "success";
    }

注意:我们设置了params属性,就意味着该请求映射的请求必须包含username才能够请求成功。

当我们传入参数用http://localhost:8080/springmvc_study02/test?username路径来访问,我们来看看结果:

1.5 @RequestMapping的headers属性

@RequestMapping的headers属性是通过当前请求的请求头信息来匹配请求;
@RequestMapping的headers属性是一个字符串类型的数组,可以通过下面四种表达是来设置匹配关系

“header”:要求请求映射的请求必须为包含 header的请求头信息
“!header”:要求请求映射的请求必须为不包含 header的请求头信息
“header=value”:要求请求映射的请求必须为包含 header的请求头信息,并且header的值必须为value
“header!=value”:要求请求映射的请求必须为包含 header的请求头信息,并且header的值必须不是value

设置请求头信息:

@RequestMapping(value = "/test",headers = "Host = localhost:8081")
    public String test(){
        return "success";
    }

2.@GetMapping(Post,Put,Delect等一样)

Get请求-@GetMapping

@GetMapping("users") 等价于@RequestMapping(value="/users",method=RequestMethod.GET)

@GetMapping("/users")public ResponseEntity> getAllUsers(){return userRepository.findAll();}
  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
引用中提到,@RequestMapping注解用于将请求映射到特定的方法上,而@GetMapping注解则相当于@RequestMapping(method=RequestMethod.GET),用于将GET请求映射到特定的方法上。 引用中介绍了如何将多个请求映射到同一个方法上。只需要在@RequestMapping注解中添加一个请求路径值列表即可实现。例如,在类上添加@RestController和@RequestMapping("/home")注解,然后在方法上添加@RequestMapping注解并指定多个请求路径值,例如"", "/page", "page*", "view/*,**/msg",这样这个方法就能够处理这些请求路径的请求。 引用提供了一个同时在类和方法上应用@RequestMapping注解的示例。通过在类上添加@RequestMapping("/home")注解,可以将类中的所有方法的请求映射到"/home"路径下。然后,在方法上添加@RequestMapping注解并指定具体的请求路径,例如"/"和"/index",这样这两个方法就能够分别处理"/home/"和"/home/index/"的请求。 所以,@RequestMapping注解是用于将请求映射到方法上的注解。它可以根据请求的不同路径进行映射,并支持在类和方法上同时使用。同时,@GetMapping注解是一种简化形式,用于将GET请求映射到方法上。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [@RequestMapping详解](https://blog.csdn.net/m0_67401055/article/details/125057030)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [@RequestMapping](https://blog.csdn.net/weixin_44471080/article/details/108518255)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值