@RequestParam
@RequestParam
您可以使用@RequestParam注解将查询参数绑定到控制器中的方法参数上。以下代码片段展示了其用法:
- Java
- Kotlin
@Controller
@RequestMapping("/pets")
public class EditPetForm {
// ...
@GetMapping
public String setupForm(@RequestParam("petId") int petId, Model model) { 1
Pet pet = this.clinic.loadPet(petId);
emodel.addAttribute("pet", pet);
return "petForm";
}
// ...
}
使用
@RequestParam。
import org.springframework.ui.set
@Controller
@RequestMapping("/pets")
class EditPetForm {
// ...
@GetMapping
_fun setupForm(@RequestParam("petId") petId: Int, model: Model): String { 1
val pet = clinic.loadPet(petId)
emodel["pet"] = pet
return "petForm"
}
// ...
}
使用
@RequestParam。
提示
Servlet API中的“请求参数”概念将查询参数、表单数据和多部分数据(multipart data)混为一谈。然而在WebFlux中,可以通过ServerWebExchange分别访问这些数据。虽然@RequestParam仅用于绑定查询参数,但你可以使用数据绑定(data binding)将查询参数、表单数据和多部分数据应用到命令对象上。
使用@RequestParam注释的方法参数默认是必需的,但你可以通过将@RequestParam的required标志设置为false,或者使用java.util.Optional包装器来声明参数,从而指定某个方法参数是可选的。
如果目标方法参数类型不是String,则会自动应用类型转换。请参阅类型转换。
当在 Map<String, String> 或 MultiValueMap<String, String> 参数上声明了 @RequestParam 注解时,该映射将填充所有查询参数。
请注意,使用@RequestParam是可选的——例如,用于设置其属性。默认情况下,任何属于简单值类型的参数(根据BeanUtils#isSimpleProperty)且没有被其他参数解析器处理的参数,都会被视为被@RequestParam注解过。