Spring:@RequestMapping

@RequestMapping 是 Spring MVC 框架中最核心的注解之一,用于将 ‌HTTP 请求映射到控制器(Controller)中的处理方法‌,实现请求路由功能。
‌基本作用‌

建立 ‌URL 路径‌ 与 ‌控制器方法‌ 之间的映射关系。

可标注在 ‌类级别‌(定义公共路径前缀)或 ‌方法级别‌(定义具体请求路径)。

常用属性‌

属性 类型 说明

value / path String[] 指定请求路径,支持多个路径(如 "/user", "/api/user")

method RequestMethod[] 指定支持的 HTTP 方法(如 GET, POST)

params String[] 限定请求必须包含特定参数(如 "username=admin")

headers String[] 限定请求必须包含特定请求头(如 "Content-Type=application/json")

consumes String[] 限定请求的内容类型(如 application/json)

produces String[] 限定响应的内容类型(如 application/xml)

示例:

@RequestMapping(value = "/user", method = RequestMethod.GET)

等价于 @GetMapping("/user")

‌派生注解(推荐使用)‌

为提升代码可读性,Spring 提供了针对常用 HTTP 方法的简化注解:

@GetMapping → @RequestMapping(method = GET)

@PostMapping → @RequestMapping(method = POST)

@PutMapping → @RequestMapping(method = PUT)

@DeleteMapping → @RequestMapping(method = DELETE)

@PatchMapping → @RequestMapping(method = PATCH)

推荐场景:当接口仅支持一种 HTTP 方法时,优先使用派生注解,语义更清晰、代码更简洁

‌组合使用示例‌

@RestController

@RequestMapping("/api/users") // 类级别:公共前缀

public class UserController {

@GetMapping("/{id}") // 方法级别:/api/users/123

public User getUser(@PathVariable Long id) {

return userService.findById(id);

}

@PostMapping // /api/users

public User createUser(@RequestBody User user) {

return userService.save(user);

}

@RequestMapping(value = "/multi", method = {RequestMethod.GET, RequestMethod.POST})

public String multiMethod() {

return "支持 GET 和 POST";

}

}

‌路径变量与通配符‌

‌路径变量‌:使用 {} 定义变量,配合 @PathVariable 获取值

@GetMapping("/user/{id}")

public String getUser(@PathVariable("id") Long userId) { ... }

‌Ant 风格通配符‌:

*:匹配任意单个路径段(如 /user/* 匹配 /user/123)

‌**:匹配任意多层路径(如 /user/**‌ 匹配 /user/123/profile)

‌注意事项‌

  • ‌默认支持所有 HTTP 方法‌:若未指定 method,则该方法响应所有请求方式(GET、POST、PUT 等)。
  • ‌避免映射冲突‌:同一路径+方法组合不能重复映射到多个方法,否则启动报错 Ambiguous mapping。
  • ‌类路径 + 方法路径 = 最终访问路径‌:如类上 /api,方法上 /user,则完整路径为 /api/user。
相关推荐
霸道流氓气质2 小时前
SpringBoot+LangChain4j+Ollama实现本地大模型语言LLM的搭建、集成和示例流程
java·spring boot·后端
iiiiyu2 小时前
常用API(SimpleDateFormat类 & Calendar类 & JDK8日期 时间 日期时间 & JDK8日期(时区) )
java·大数据·开发语言·数据结构·编程语言
迷藏4942 小时前
# 发散创新:基于Selenium的自动化测试框架重构与实战优化在当今快速迭代的软件开
java·python·selenium·测试工具·重构
浮游本尊2 小时前
MES 实施计划从新建到自动流转:三条入口、一套存储、两类驱动
后端
Nyarlathotep01132 小时前
LockSupport工具类
java·后端
jieyucx2 小时前
Go 语言零基础入门:编写第一个 Hello World 程序
开发语言·后端·golang
一点一一2 小时前
nestjs+langchain:大模型的基本调用、对message的
人工智能·后端
阿巴斯甜2 小时前
BiFunction的使用
java
NineData2 小时前
NineData将亮相2026德国汉诺威工业博览会
运维·数据库·后端