在这个快速教程中,我们将探索 Spring 的 @RequestParam 注解。
简单地说,我们可以使用 @RequestParam 从请求中提取查询参数、表单参数甚至文件。
我们将讨论如何使用 @RequestParam 及其属性。我们还将讨论 @RequestParam 和 @PathVariable 之间的区别。
假设我们有一个端点 /api/foos,它接受一个名为 id 的查询参数:
@GetMapping("/api/foos")
@ResponseBody
public String getFoos(@RequestParam String id) {
return "ID: " + id;
}
在此示例中,我们使用 @RequestParam 来提取 id 查询参数。
一个简单的 GET 请求会调用 getFoos:
http://localhost:8080/api/foos?id=abc
----
ID: abc
接下来,让我们看看注解的属性:name、value、required 和defaultValue。
在前面的例子中,变量名和参数名都是一样的。
虽然有时我们希望这些有所不同。 或者,如果我们不使用 Spring Boot,我们可能需要进行特殊的编译时配置,否则参数名称实际上不会在字节码中。
但好的是我们可以使用 name 属性配置 @RequestParam 名称:
@PostMapping("/api/foos")
@ResponseBody
public String addFoo(@RequestParam(name = "id") String fooId, @RequestParam String name) {
return "ID: " + fooId + " Name: " + name;
}
默认情况下需要使用 @RequestParam 注释的方法参数。
这意味着如果请求中不存在参数,我们将收到错误消息:
GET /api/foos HTTP/1.1
-----
400 Bad Request
Required String parameter 'id' is not present
不过,我们可以将我们的 @RequestParam 配置为可选的,使用 *required *属性:
@GetMapping("/api/foos")
@ResponseBody
public String getFoos(@RequestParam(required = false) String id) {
return "ID: " + id;
}
在这种情况下,两者:
http://localhost:8080/api/foos?id=abc
----
ID: abc
和
http://localhost:8080/api/foos
----
ID: null
将正确调用该方法。
未指定参数时,方法参数绑定为null。
我们还可以使用 defaultValue 属性为 @RequestParam 设置默认值:
@GetMapping("/api/foos")
@ResponseBody
public String getFoos(@RequestParam(defaultValue = "test") String id) {
return "ID: " + id;
}
**这就像required=false,因为用户不再需要提供参数:
http://localhost:8080/api/foos
----
ID: test
尽管如此,我们仍然可以提供它:
http://localhost:8080/api/foos?id=abc
----
ID: abc
请注意,当我们设置 *defaultValue * 属性时,required 确实设置为 false。
我们也可以有多个参数而不定义它们的名称或仅使用 Map: 来计数
@PostMapping("/api/foos")
@ResponseBody
public String updateFoos(@RequestParam Map<String,String> allParams) {
return "Parameters are " + allParams.entrySet();
}
然后将反映发送的任何参数:
curl -X POST -F 'name=abc' -F 'id=123' http://localhost:8080/api/foos
-----
Parameters are {[name=abc], [id=123]}
单个 @RequestParam 可以有多个值:
@GetMapping("/api/foos")
@ResponseBody
public String getFoos(@RequestParam List<String> id) {
return "IDs are " + id;
}
Spring MVC 将映射一个逗号分隔的id参数:
http://localhost:8080/api/foos?id=1,2,3
----
IDs are [1,2,3]
或单独的id参数列表:
http://localhost:8080/api/foos?id=1&id=2
----
IDs are [1,2]
@RequestParam 和 @PathVariable 都可用于从请求 URI 中提取值,但它们略有不同。
虽然 @RequestParams 从查询字符串中提取值,但 @PathVariables 从 URI 路径中提取值:
@GetMapping("/foos/{id}")
@ResponseBody
public String getFooById(@PathVariable String id) {
return "ID: " + id;
}
然后,我们可以根据路径进行映射:
http://localhost:8080/foos/abc
----
ID: abc
对于 @RequestParam, 它将是:
@GetMapping("/foos")
@ResponseBody
public String getFooByIdUsingQueryParam(@RequestParam String id) {
return "ID: " + id;
}
这会给我们相同的响应,只是一个不同的 URI:
http://localhost:8080/foos?id=abc
----
ID: abc
因为 @PathVariable 从 URI 路径中提取值,所以它没有被编码。另一方面,@RequestParam 是。
使用前面的示例,ab+c 将按原样返回:
http://localhost:8080/foos/ab+c
----
ID: ab+c
但是对于 a @RequestParam 请求,参数是 URL 解码的:
http://localhost:8080/foos?id=ab+c
----
ID: ab c
@RequestParam 和@PathVariable 都可以是可选的。**
从 Spring 4.3.3 开始,我们可以使用 required 属性使 @PathVariable 可选:
@GetMapping({"/myfoos/optional", "/myfoos/optional/{id}"})
@ResponseBody
public String getFooByOptionalId(@PathVariable(required = false) String id){
return "ID: " + id;
}
那么,我们可以这样做:
http://localhost:8080/myfoos/optional/abc
----
ID: abc
或者:
http://localhost:8080/myfoos/optional
----
ID: null
对于@RequestParam,我们还可以使用我们在上一节中看到的 required 属性。
请注意,我们在将 @PathVariable 设为可选时应小心,以避免路径冲突。
在本文中,我们了解了如何使用 @RequestParam 以及 @RequestParam 和 @PathVariable 之间的区别。
版权说明 : 本文为转载文章, 版权归原作者所有 版权申明
原文链接 : https://www.dailycodebuffer.com/spring-requestparam-annotation/
内容来源于网络,如有侵权,请联系作者删除!