我们在开发 REST API 的过程中,经常需要传递参数,那么,我们可以怎么做呢?本文,我们将探讨 Spring Boot 项目中三种传递参数的方式,如下👇
@PathVariable@RequestParam@RequestBody
什么是
REST API?REST API 是基于REST架构原则设计的一组规范和约定,用于在不同软件系统之间进行通信。
测试环境
macOs Monterey 12.4 (Apple M1)IntelliJ IDEA 2021.2.2(Ultimate Edition)java --version (17.0.7)maven version 3.9.2Spring Boot version 3.2.0Postman version 8.12.1
相关依赖
这里我们不考虑数据库、security 等的引入,相关的依赖比较简单,如下:
xml
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
spring-boot-starter-web是用于开发基于Spring Boot的Web应用程序的起步依赖,支持RESTful API的开发。
PS:当然,我们后期可以引入数据库、JWT等操作,但是,这个知识点并不是本文的重点
@PathVariable 注解
@PathVariable 注解 用于从 URI 中提取模版变量,并将其绑定到方法的参数上。如下:
java
@RestController
@RequestMapping("/api")
public class HelloController {
@GetMapping("/hello/{name}")
public String sayHello(@PathVariable String name) {
return "Hello, " + name + "!";
}
}
启动程序,在 postman 中输入 http://localhost:8080/api/hello/Jimmy,即可看到输出 Hello, Jimmy! 的返回信息。如下图👇

上面的 @GetMapping("/hello/{name}") 和 @PathVariable String name 其实是省略了同名的写法,如果 GetMapping 中路径变量和方法的参数变量不同名,我们需要做下调整。
java
@RestController
@RequestMapping("/api")
public class HelloController {
@GetMapping("/hello/{username}")
public String sayHello(@PathVariable("username") String name) {
return "Hello, " + name + "!";
}
}
上面的运行效果跟截图展示的效果一样。
@RequestParam 注解
@RequestParam 注解 将 HTTP 请求中的参数值映射到方法的参数上。如下示范:
java
@RestController
@RequestMapping("/api")
public class ParamController {
@RequestMapping("/param")
public String requestParamDemo(@RequestParam String name) {
return "Hello, " + name + "!";
}
}
我们在 postman 上请求 http://localhost:8080/api/param?name=Jimmy,可看到输出 Hello, Jimmy! 的字样。

上面的代码中传参还可以是下面的这种推荐写法:
java
@RestController
@RequestMapping("/api")
public class ParamController {
@RequestMapping("/param")
public String requestParamDemo(@RequestParam("username") String name) {
return "Hello, " + name + "!";
}
}
这个时候,我们在 postman 上传递的 username 值,其实就是赋予了变量 name,如下👇

@RequestBody 注解
@RequestBody 注解 注解用于处理 HTTP 请求体的内容映射到方法的参数上。使用 @RequestBody 注解可以将请求体的内容转化为相应的 Java 对象,以便在方法中处理。如下例子:
我们先创建一个 bean 类:
java
@Setter
@Getter
public class Person {
String username;
}
然后创建一个 controller:
java
@RestController
@RequestMapping("/api")
public class requestBodyController {
@RequestMapping("/request-body")
public String requestBodyDemo(@RequestBody Person person) {
return "Hello, " + person.getUsername() + "!";
}
}
在 postman 上请求接口 http://localhost:8080/api/request-body,在 Body 请求输入 json 数据,如下:

总结
本文中,我们一起学习了 @PathVariable 注解、RequestParam 注解和 RequestBody 注解来处理 HTTP 请求的传递参数。本文中的案例,我们都是使用了 Get 请求来模拟,但是实际上,RequestBody 用得更多的是在 POST 新增记录和 PUT 修改记录的情况。三个注解搭配使用,完成参数的传递。