@RequestMapping详解

2022年05月15日 阅读数:9
这篇文章主要向大家介绍@RequestMapping详解,主要内容包括基础应用、实用技巧、原理机制等方面,希望对大家有所帮助。

你们好,我是郭尕~
在这里插入图片描述
今天主要介绍的就是哆啦a梦的法宝之一——任意门,咱们知道任意门能够随意通往本身想要到达的地方,直接就是一扇门,打开就到了另一个地方,很是神奇。
而在咱们的Java web开发中也有一个一样神奇的法宝,能够为咱们节省好多时间和代码,从而实现浏览器与服务器之间的映射,它就是——RequestMapping注解,下面咱们一块儿来了解一下吧。
html

@RequestMappingjava

前言

咱们在实际的开发当中,一个控制器中不必定只有一个方法,而这些方法都是用来处理请求的,那么怎样才能将请求与处理方法一一对应呢,固然是经过 RequestMapping 注解来处理这些映射请求,也就是经过它来指定控制器能够处理哪些URL请求。web

@RequestMapping

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

1.@RequestMapping能够标注的位置

1.1 标注在方法上

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

    @RequestMapping("/testRequest")
    public String testRequest(){
   
   
        return "success";
    }
}

此时请求映射所映射的请求的请求路径为:http://http://localhost:8080/springmvc_study02/testRequest
在这里插入图片描述数组

注意:springmvc_study02是项目名称浏览器

1.2 标注在类和方法上

  • 用于类上,表示类中的全部响应请求的方法都是以该地址做为父路径。
@Controller
@RequestMapping("/hello")
public class RequestMappingController {
   
   

    @RequestMapping("/testRequest")
    public String testRequest(){
   
   
        return "success";
    }
}

此时请求映射所映射的请求的请求路径为:http://localhost:8080/springmvc_study02/hello/testRequest
在这里插入图片描述
注意:当你在类上添加RequestMapping注解后,若是要请求映射,就意味着请求要先映射到标注类的位置,而后再映射到该类的方法上。若是不加就会出现以下错误
在这里插入图片描述服务器

2. @RequestMapping的属性

  • 咱们能够先查看一下源码:按住Ctrl键,鼠标点击RequestMapping注解就能够看到下面的界面
    在这里插入图片描述
  • 在源码中咱们能够看到@RequestMapping的全部属性,那么接下来就一块儿看一看这些属性

2.1 @RequestMapping的value属性*

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

设置value属性的值:mvc

@Controller
public class RequestMappingController {
   
   

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

在浏览器中输入下面路径进行测试:
在这里插入图片描述
在这里插入图片描述
注意:从上面两张图咱们可以看到,这时的请求映射所映射的请求的请求路径为选择value数组中的任意一个均可以。app

2.2 @RequestMapping的method属性*

  • @RequestMapping的method属性是经过当前请求的请求方式来匹配请求;
  • 浏览器向服务器发送请求,请求方式有不少GET、HEAD、POST、PUT、PATCH、DELETE、OPTIONS、TRACE。能够使用 method 属性来约束请求方式。

设置请求方式为get:svg

@Controller
public class RequestMappingController {
   
   

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

以post方式请求:

<form th:action="@{/testRequest}" method="post">
    <input type="submit">
</form>

请求结果:
在这里插入图片描述
注意:咱们在@RequestMapping注解里加一个方法限定:method = RequestMethod.GET,则请求必须是get的,不然就会发生以上的错误。

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

扩展:

  • @GetMapping:处理get方式请求的映射
  • @PostMapping:处理post方式请求的映射
  • @PutMapping:处理put方式请求的映射
  • @DeleteMapping:处理delete方式请求的映射

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

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

2.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路径来访问,咱们来看看结果:
在这里插入图片描述
当给params属性设置多个属性值时,必须同时知足才可以请求成功,不然会出现下面的错误
在这里插入图片描述

2.4 @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";
    }

请求结果:
在这里插入图片描述
注意:若是当前请求不知足headers属性,此时页面就会显示404错误,即资源未找到。

学完这个法宝,是否是感受很是有意思呢,那还不赶忙去试试。