@RequestMapping属性详解 - SpringMVC高手进阶

写在最后

为了这次面试,也收集了很多的面试题!

以下是部分面试题截图

Java程序员秋招三面蚂蚁金服,我总结了所有面试题,也不过如此

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

// 指定请求的方式,是一个RequsetMethod数组,可以配置多个方法

RequestMethod[] method() default {};

// 指定参数的类型

String[] params() default {};

// 指定请求头内容

String[] headers() default {};

// 指定数据请求的格式

String[] consumes() default {};

// 指定返回的内容类型

String[] produces() default {};

}

  • 如上源码所示,在@Target中有两个属性,分别为 ElementType.METHOD 和 ElementType.TYPE ,也就是说@RequestMapping 可以在方法和类的声明中使用

  • 可以看到注解中的属性除了 name() 返回的字符串,其它的方法均返回数组,也就是可以定义多个属性值,例如 value() 和 path() 都可以同时定义多个字符串值来接收多个URL请求

RequestMapping属性介绍


1、name

此处name属性,相当于方法的注释,使方法更易理解

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

@ResponseBody

public String login() {

return “success”;

}

官方文档说:它能让你非常方便的在JSP页面上使用它,形如这样子可以直接通过静态页面调用:

<%@ taglib uri=“http://www.springframework.org/tags” prefix=“s” %>

Get Address

2、value

@Controller

@RequestMapping(“user”) //此处如果不省略,则为@RequestMapping(value=“user”)

public class UserController {

@RequestMapping(“login”)

@ResponseBody

public String login() {

return “success”;

}

}

指定请求的实际地址,指定的地址可以是URI 模板模式(Template Pattern);

由于value属性是@RequestMapping注释的默认属性,因此如果只有唯一的属性,则可以省略该属性名,如果有超过一个属性,则必须写上value属性名称。即如下两个标注含义一样

@RequestMapping(value=“login”)

@RequestMapping(“login”)

value属性支持通配符匹配:

@RequestMapping(value=“login/*”);

即:http://localhost:8080/login/1或者http://localhost:8080/login/hahaha都能够正常访问该接口

此处通过URL:http://localhost:8080/user/login进行访问,将由login()方法进行处理

3、path

与value同义,path(value)(path 和 value 互相引用,参见RequestMapping接口源码)

path属性,和1中的value属性使用一致,两者都是用来作为映射使用的。

@RequestMapping(value=“login”)、@RequestMapping(path=“login”),这两种情况都能对login()方法进行访问

path属性支持通配符匹配:

@RequestMapping(path=“login/*”);

即:http://localhost:8080/login/1或者http://localhost:8080/login/abc都能够正常访问

4、method

指定请求类型, 如GET、POST、PUT、DELETE等;

@RequestMapping(value = “login”,method = RequestMethod.GET)

@ResponseBody

public String login() {

return “success”;

}

以上方法表示,该方法只支持GET请求。

此处也可以为

@RequestMapping(value = “login”,method = {RequestMethod.GET,RequestMethod.POST})

说明该方法可以同时支持GET和POST请求。

如果没有method属性,则说明该方法支持全部的HTTP请求。

5、params

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

@RequestMapping(value = “login”,params = “flag”)

@ResponseBody

public String login() {

return “success”;

}

以上方法,说明请求中必须包含flag参数才能执行该请求,flag参数值不做要求

http://localhost:8080/login?flag=xxx // 正常访问

http://localhost:8080/login // 无法访问

@RequestMapping(value = “login”,params = “flag=true”)

@ResponseBody

public String login() {

return “success”;

}

以上方法,说明请求中必须包含flag参数,而且参数值必须为true才能执行该请求

http://localhost:8080/login?flag=true // 正常访问

http://localhost:8080/login?flag=false // 无法访问

http://localhost:8080/login // 无法访问

6、headers

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

  • 请求头部(Request

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

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

该属性指定,请求中必须包含某些指定的header值,才能够让该方法处理请求

如Chrome浏览器:

可以通过点击F12(进入开发者模式)---->Network---->Name中点击网页---->右侧查看Headers即可,下边是我电脑中的一个请求头部示例:

Request Headers

Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,/;q=0.8

Accept-Encoding:gzip, deflate, sdch

Accept-Language:zh-CN,zh;q=0.8

Cache-Control:max-age=0

Connection:keep-alive

Cookie:JSESSIONID=210075B5E521CWE3CDE938076295A57A

Host:localhost:8080

Upgrade-Insecure-Requests:1

User-Agent:Mozilla/5.0 (Macintosh; Intel Mac OS X 10_9_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.93

// 表示只接收本机发来的请求

@RequestMapping(path = “/login”, headers=“Referer=http://localhost:8080”)

public String login() {

return “success”;

最后

金三银四马上就到了,希望大家能好好学习一下这些技术点

学习视频:

大厂面试真题:

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

, headers=“Referer=http://localhost:8080”)

public String login() {

return “success”;

最后

金三银四马上就到了,希望大家能好好学习一下这些技术点

学习视频:

[外链图片转存中…(img-92fCkJUX-1715804366758)]

大厂面试真题:

[外链图片转存中…(img-Np9gWE88-1715804366758)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 27
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
@RequestMapping注解是Spring MVC中最常用的注解之一,它用于将请求映射到控制器的处理程序方法上。通过使用@RequestMapping注解,我们可以轻松地将URL映射到处理程序方法,并且可以通过使用不同的HTTP方法(例如GET、POST等)指定不同的处理程序方法。以下是一个@RequestMappingSpringMVC中的应用实例: ``` @Controller @RequestMapping("/user") public class UserController { @GetMapping("/list") public String listUsers(Model model) { // 处理获取用户列表的逻辑 List<User> userList = userService.getUserList(); model.addAttribute("userList", userList); return "user/list"; } @GetMapping("/{userId}") public String getUser(@PathVariable Long userId, Model model) { // 处理获取用户信息的逻辑 User user = userService.getUserById(userId); model.addAttribute("user", user); return "user/detail"; } @PostMapping("/add") public String addUser(@ModelAttribute User user) { // 处理添加用户的逻辑 userService.addUser(user); return "redirect:/user/list"; } @PostMapping("/update/{userId}") public String updateUser(@PathVariable Long userId, @ModelAttribute User user) { // 处理更新用户信息的逻辑 userService.updateUser(userId, user); return "redirect:/user/" + userId; } @PostMapping("/delete/{userId}") public String deleteUser(@PathVariable Long userId) { // 处理删除用户的逻辑 userService.deleteUser(userId); return "redirect:/user/list"; } } ``` 上面的示例中,我们使用@Controller注解来定义一个控制器类,并使用@RequestMapping注解来指定请求的URL路径。例如,我们使用@GetMapping注解将请求映射到listUsers()方法,这个方法返回一个包含用户列表的模型,并将其渲染到名为“user/list”的视图中。类似地,我们使用@PostMapping注解将请求映射到addUser()方法,这个方法处理添加用户的逻辑,并将其重定向到用户列表页面。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值