@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);
		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中的“请求参数”概念将查询参数、表单数据和多部分数据合并为一个。但是,在WebFlux中,每个都通过ServerWebExchange单独访问。虽然@RequestParam仅绑定到查询参数,但您可以使用数据绑定将查询参数、表单数据和多部分数据应用到命令对象

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

如果目标方法参数类型不是String,则会自动应用类型转换。请参阅类型转换

当在Map<String, String>MultiValueMap<String, String>参数上声明@RequestParam注解时,该映射将填充所有查询参数。

请注意,@RequestParam的使用是可选的,例如,用于设置其属性。默认情况下,任何作为简单值类型(由BeanUtils#isSimpleProperty确定)且未被任何其他参数解析器解析的参数都将被视为已注释为@RequestParam