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

@RequestParam

你可以使用 @RequestParam 注解将查询参数绑定到控制器中的方法参数上。以下代码片段展示了其用法:spring-doc.cadn.net.cn

@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 使用 @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)
		model["pet"] = pet
		return "petForm"
	}

	// ...
}
1 使用 @RequestParam
Servlet API 中的“请求参数”(request parameter)概念将查询参数、表单数据和多部分文件(multiparts)混为一谈。然而在 WebFlux 中,每种类型都通过 ServerWebExchange 单独访问。虽然 @RequestParam 仅绑定到查询参数,但你可以使用数据绑定将查询参数、表单数据和多部分文件绑定到一个命令对象上。

默认情况下,使用 @RequestParam 注解的方法参数是必需的,但你可以通过将 @RequestParam 的 required 标志设置为 false,或使用 java.util.Optional 包装器声明参数,来指定该方法参数是可选的。spring-doc.cadn.net.cn

如果目标方法参数类型不是 String,则会自动应用类型转换。参见类型转换spring-doc.cadn.net.cn

当在 @RequestParam 注解声明于 Map<String, String>MultiValueMap<String, String> 类型的参数上时,该 Map 将被填充所有查询参数。spring-doc.cadn.net.cn

请注意,使用 @RequestParam 是可选的——例如,用于设置其属性。默认情况下,任何简单值类型(由 BeanUtils#isSimpleProperty 判定)且未被其他参数解析器解析的参数,都会被当作已使用 @RequestParam 注解处理。spring-doc.cadn.net.cn