详解SpringMVC中的@RequestMapping注解

 更新时间:2023年07月21日 10:09:03   作者:普通网友  
这篇文章主要介绍了SpringMVC中@RequestMapping注解,@RequestMapping注解是一个用来处理请求地址映射的注解,可用于映射一个请求或一个方法,可以用在类或方法上,需要的朋友可以参考下

前言

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

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

1.@RequestMapping可以标注的位置

1.1 标注在方法上

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

@Controller public class RequestMappingController {

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

此时请求映射所映射的请求的请求路径为:////localhost:8080/springmvc_study02/testRequest

在这里插入图片描述

注意:springmvc_study02是项目名称

1.2 标注在类和方法上

  • 用于类上,表示类中的所有响应请求的方法都是以该地址作为父路径。
@Controller 
@RequestMapping(“/hello”) 
public class RequestMappingController {
    @RequestMapping("/testRequest")
    public String testRequest(){
        return "success";
    }
}

此时请求映射所映射的请求的请求路径为://localhost:8080/springmvc_study02/hello/testRequest

在这里插入图片描述

注意:当你在类上添加RequestMapping注解后,如果要请求映射,就意味着请求要先映射到标注类的位置,然后再映射到该类的方法上。如果不加就会出现如下错误

在这里插入图片描述

2. @RequestMapping的属性

  • 我们可以先查看一下源码:按住Ctrl键,鼠标点击RequestMapping注解就可以看到下面的界面

在这里插入图片描述

  • 在源码中我们可以看到@RequestMapping的所有属性,那么接下来就一起看一看这些属性

2.1 @RequestMapping的value属性*

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

设置value属性的值:

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

在浏览器中输入下面路径进行测试:

在这里插入图片描述

在这里插入图片描述

注意:从上面两张图我们能够看到,这时的请求映射所映射的请求的请求路径为选择value数组中的任意一个都可以。

2.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方式请求:

<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才能够请求成功。

当我们传入参数用//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错误,即资源未找到。

到此这篇关于详解SpringMVC中的@RequestMapping注解的文章就介绍到这了,更多相关SpringMVC的@RequestMapping注解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring boot应用启动后首次访问很慢的解决方案

    Spring boot应用启动后首次访问很慢的解决方案

    这篇文章主要介绍了Spring boot应用启动后首次访问很慢的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • java实现自定义日期选择器的方法实例

    java实现自定义日期选择器的方法实例

    日期选择器是我们日常开发中经常需要用到的一个功能,下面这篇文章主要给大家介绍了关于利用java实现自定义日期选择器的相关资料,文中给出了详细的示例代码,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-10-10
  • java编程下字符串的16位,32位md5加密实现方法

    java编程下字符串的16位,32位md5加密实现方法

    下面小编就为大家带来一篇java编程下字符串的16位,32位md5加密实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • Spring-retry实现循环重试功能

    Spring-retry实现循环重试功能

    这篇文章主要介绍了Spring-retry 优雅的实现循环重试功能,通过@Retryable注解,优雅的实现循环重试功能,需要的朋友可以参考下
    2023-07-07
  • Java文件字符输入流FileReader读取txt文件乱码的解决

    Java文件字符输入流FileReader读取txt文件乱码的解决

    这篇文章主要介绍了Java文件字符输入流FileReader读取txt文件乱码的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • 详述IntelliJ IDEA插件的安装及使用方法(图解)

    详述IntelliJ IDEA插件的安装及使用方法(图解)

    本篇文章主要介绍了详述 IntelliJ IDEA 插件的安装及使用方法(图解),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • Java import static及import原理区别解析

    Java import static及import原理区别解析

    这篇文章主要介绍了Java import static及import原理区别解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Sonar编译问题对应:File [...] can''t be indexed twice.

    Sonar编译问题对应:File [...] can''t be indexed twice.

    今天小编就为大家分享一篇关于Sonar编译问题对应:File [...] can't be indexed twice.,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • java 继承访问成员变量代码实例

    java 继承访问成员变量代码实例

    这篇文章主要介绍了java 继承访问成员变量代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-10-10
  • springboot中.yml文件参数的读取方式

    springboot中.yml文件参数的读取方式

    这篇文章主要介绍了springboot中.yml文件参数的读取方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02

最新评论