@RequestParam
您可以使用 @RequestParam
注解将查询参数绑定到控制器中的方法参数。以下代码段展示了用法:
- Java
-
@Controller @RequestMapping("/pets") public class EditPetForm { // ... @GetMapping public String setupForm(@RequestParam("petId") int petId, Model model) { 1 Pet pet = this.clinic.loadPet(petId); model.addAttribute("pet", pet); return "petForm"; } // ... }
1 | Using @RequestParam .
|
2 | Using @RequestParam . |
Servlet API “request parameter” 概念将查询参数、表单数据和多部分合并为一个。但是,在 WebFlux 中,每个部分都是通过 |
默认情况下,使用 @RequestParam
注解的方法参数是必需的,但您可以通过将 @RequestParam
的必填标志设为 false
或声明一个采用 java.util.Optional
封装器类型的自变量来指定方法参数是可选的。
如果目标方法参数类型不是 String
,则会自动应用类型转换。请参阅 Type Conversion。
当在 Map<String, String>
或 MultiValueMap<String, String>
自变量上声明 @RequestParam
注解时,地图将填充所有查询参数。
请注意,使用 @RequestParam
是可选的,例如,设置其属性。 默认情况下,任何简单值类型的参数(根据 BeanUtils#isSimpleProperty 确定),并且并未通过任何其他参数解析器解析,都将视为用 @RequestParam
注释。