对于最新的稳定版本,请使用 Spring Framework 6.2.10spring-doc.cadn.net.cn

您可以使用@ModelAttribute注解:spring-doc.cadn.net.cn

本节讨论@ModelAttributemethods — 前面列表中的第二项。控制器可以有任意数量的@ModelAttribute方法。 所有这些方法都是在之前调用@RequestMapping方法。 一个@ModelAttribute方法也可以通过@ControllerAdvice. 有关更多详细信息,请参阅控制器建议部分。spring-doc.cadn.net.cn

@ModelAttribute方法具有灵活的方法签名。它们支持许多相同的参数作为@RequestMapping方法,但@ModelAttribute本身或任何东西与请求正文相关。spring-doc.cadn.net.cn

以下示例显示了@ModelAttribute方法:spring-doc.cadn.net.cn

@ModelAttribute
public void populateModel(@RequestParam String number, Model model) {
	model.addAttribute(accountRepository.findAccount(number));
	// add more ...
}
@ModelAttribute
fun populateModel(@RequestParam number: String, model: Model) {
	model.addAttribute(accountRepository.findAccount(number))
	// add more ...
}

以下示例仅添加一个属性:spring-doc.cadn.net.cn

@ModelAttribute
public Account addAccount(@RequestParam String number) {
	return accountRepository.findAccount(number);
}
@ModelAttribute
fun addAccount(@RequestParam number: String): Account {
	return accountRepository.findAccount(number)
}
如果未显式指定名称,则会根据Object类型,如 javadoc 中所述Conventions. 始终可以使用重载的addAttributemethod 或通过name属性@ModelAttribute(对于返回值)。

您还可以使用@ModelAttribute作为方法级注释@RequestMapping方法 在这种情况下,返回值@RequestMapping方法被解释为模型 属性。 这通常不是必需的,因为它是 HTML 控制器中的默认行为,除非返回值是String否则将被解释为视图名称。@ModelAttribute还可以自定义模型属性名称,如以下示例所示:spring-doc.cadn.net.cn

@GetMapping("/accounts/{id}")
@ModelAttribute("myAccount")
public Account handle() {
	// ...
	return account;
}
@GetMapping("/accounts/{id}")
@ModelAttribute("myAccount")
fun handle(): Account {
	// ...
	return account
}