【学习笔记】SpringMVC—@RequestMapping注解


二、@RequestMapping注解的位置


我们可以查看一下@RequestMapping的源码来进行分析:

@Target({ElementType.TYPE, ElementType.METHOD})

通过上面两个参数我们能知道@RequestMapping这个注解能够标示在 类和方法 上面。而表示在不同的地方则作用也是不一样的。

接下来我们通过一些例子来进行分析。

注解在方法上:

@Controller

public class hello {

@RequestMapping(“/hello”)

public String hello(){

return “hello”;

}

运行结果:

在这里插入图片描述

当标示在方法时,这个就直接和我们的服务器请求发生相关联,就能匹配所发送的请求。

OK,接下来我们标示在类上面时:

@Controller

@RequestMapping(“MVC”)

public class hello {

@RequestMapping(“/hello”)

public String hello(){

return “hello”;

}

当我们还是和上面上面一样对:(http://localhost:8080/SpringMVC/hello)这个地址进行请求时则会发生什么呢?

运行结果:

在这里插入图片描述

能看见服务器是直接给我们报404。则当我们在hello前面加上一个MVC时,来看看结果。

运行结果:

在这里插入图片描述

则是能够请求成功的,所以我们大概能理解了如果在类上标示后就会多了一个初始化路径。

总结:

  • @RequestMapping标识一个类:设置映射请求的请求路径的初始信息

  • @RequestMapping标识一个方法:设置映射请求请求路径的具体信息


三、@RequestMapping注解的name属性


name属性: 方法注释。

例如:

@RequestMapping(value = “login”,name = “用户登录”)

public String login() {

return “success”;

}

这个目前还是比较少见了,因为是作用在jsp上,所以这个大家可以了解了解。面试的时候也可能会被问题到SpringMVC的属性有哪些,这个就可以作为一个回答。


四、@RequestMapping注解的value属性


value属性的值是一个String数组,他能设置多个值,使得多个请求地址指向同一个资源

如果出错,会报 404找不到资源。

正如在上面的例子我们是直接把value省略直接写的属性值。一般还是需要加上去。

public class hello {

@RequestMapping(value = “/hello”)

public String hello(){

return “hello”;

}

使用多个请求地址:

@Controller

public class hello {

@RequestMapping(value = {“/hello”,“/Hello”})

public String hello(){

return “hello”;

}

当我们访问hello时:

在这里插入图片描述

当我们访问Hello时;

在这里插入图片描述

通过上面的两个例子我们能知道他们请求的是同一个资源


五、@RequestMapping注解的method属性


method 的方法一般有: GET、POST、PUT、DELETE等;

@RequestMapping注解的 method 属性是一个 RequestMethod 类型的数组,表示该请求映射能够匹配多种请求方式的请求。

注: 如果请求方式是不满足 RequestMethod 中的请求方法,则浏览器报错405:Request method ‘POST’ not supported

使用案例:

@Controller

public class hello {

@RequestMapping(

value = {“/hello”,“/Hello”},

method = {RequestMethod.GET, RequestMethod.POST}

)

public String hello(){

return “hello”;

}

上述代码我们能看到这个请求资源是可以接收GET,POST方法的。在之前我们都是没有加这个 method 参数的但是我们还是能够对这个资源进行请求的原因就是因为在默认情况下,则是可以接收任何的请求方式。

补充:

1、在 SpringMVC 中还有@RequestMapping的一些派生注解:

  • 处理get请求—GetMapping。

  • 处理post请求— PostMapping。

  • 处理put请求— PutMapping。

  • 处理delete请求— DeleteMapping。

2、刚才提到了常用的请求有 get、post、put和delete 。但是在服务器中只接受 get 请求和 post 请求,如果在使用了from表单时使用了其他方法的话,则都会按照默认方法 get 来进行处理。

如果需要发送 put或者delete请求,则需要用到Spring中的过滤器HiddenHttpMethodFilter。


六、@RequestMapping注解的Params属性


该属性指定,请求中必须包含params属性规定的参数时,才能执行该请求。

  • ”params“ — 请求必须携带 params 参数。

  • ”!params“—请求 不能 携带 params 参数。

  • “params = value” —请求 必须 携带参数,且参数 params 是等于 value 的。

  • ”!params = value“ —请求 必须 携带参数,且参数 params 是不等于 value的。

测试案例:

测试params

@RequestMapping(

value = “/test”,

params = “!username”,

)

public String testParams(){

return “success”;

}

通过代码我们能得到我们是必须需要请求不能携带参数的,如果携带参数就会出现错误。

运行结果:

在这里插入图片描述


七、@RequestMapping注解的headers属性


在学习这个属性前,我想问大家什么是 header ?大家是不是很熟悉?

header:

  • 用于HTTP协义交互的信息被称为HTTP报文,客户端发送的HTTP报文被称为请求报文,服务器发回给客户端的HTTP报文称为响应报文,报文由报文头部和报文体组成。

  • 请求头部(Request Headers):请求头包含许多有关客户端环境和请求正文的信息,例如浏览器支持的语言、请求的服务器地址、客户端的操作系统等。

  • 响应头部(Rsponse Headers):响应头也包含许多有用的信息,包括服务器类型、日期、响应内容的类型及编码,响应内容的长度等等。

和 params 使用方式相似:

  • “header”:要求请求映射所匹配的请求必须携带header请求头信息。

  • “!header”:要求请求映射所匹配的请求必须不能携带header请求头信息。

  • “header=value”:要求请求映射所匹配的请求必须携带header请求头信息且header=value。

  • “header!=value”:要求请求映射所匹配的请求必须携带header请求头信息且header!=value。

我们来测试一下代码吧:

@RequestMapping(

//我们的一般端口是8080

headers = “Host=localhost:8081”

)

public String testParams(){

return “success”;

}

我们请求8081端口号,来看一下运行结果:

在这里插入图片描述

我们这个肯定是访问不到的啦。所以这个参数一般一般可以用来设置请求头。


八、@RequestMapping注解的consumes属性


consumes: 指定处理请求的提交内容类型(Content-Type),例如:application/json、text/html时,才能够让该方法处理请求。

@RequestMapping(

value = “/test”,

params = “username”,

headers = “Host=localhost:8080”,

consumes = “application/json”

)

public String testParams(){

return “success”;

}


九、@RequestMapping注解的produces属性


produces: 指定返回的内容类型,返回的内容类型必须是request请求头(Accept)中所包含的类型。

@RequestMapping(

value = “/test”,

params = “username”,

headers = “Host=localhost:8080”,

consumes = “application/json”,

//可设置编码!

produces = “application/json , charset=utf-8”

)

public String testParams(){

return “success”;

}


十、@RequestMapping注解支持ant路径风格


  • ?:表示任意的单个字符

  • *:表示任意的0个或多个字符

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

每年转战互联网行业的人很多,说白了也是冲着高薪去的,不管你是即将步入这个行业还是想转行,学习是必不可少的。作为一个Java开发,学习成了日常生活的一部分,不学习你就会被这个行业淘汰,这也是这个行业残酷的现实。

如果你对Java感兴趣,想要转行改变自己,那就要趁着机遇行动起来。或许,这份限量版的Java零基础宝典能够对你有所帮助。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!**

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

每年转战互联网行业的人很多,说白了也是冲着高薪去的,不管你是即将步入这个行业还是想转行,学习是必不可少的。作为一个Java开发,学习成了日常生活的一部分,不学习你就会被这个行业淘汰,这也是这个行业残酷的现实。

如果你对Java感兴趣,想要转行改变自己,那就要趁着机遇行动起来。或许,这份限量版的Java零基础宝典能够对你有所帮助。

[外链图片转存中…(img-R8RaIOxL-1713411540079)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值