此版本仍在开发中,尚不被认为是稳定的。对于最新的稳定版本,请使用 Spring Framework 6.2.10spring-doc.cadn.net.cn

类型转换

一些带注释的控制器方法参数表示String基于请求的输入(例如@RequestParam,@RequestHeader,@PathVariable,@MatrixVariable@CookieValue) 如果参数声明为String.spring-doc.cadn.net.cn

对于这种情况,将根据配置的转换器自动应用类型转换。 默认情况下,简单类型 (int,long,Date等)都得到了支持。您可以自定义 通过WebDataBinder(参见DataBinder)或通过注册Formatters使用FormattingConversionService. 请参阅 Spring 字段格式。spring-doc.cadn.net.cn

类型转换中的一个实际问题是处理空的 String 源值。 如果这样的值变成null类型转换的结果。 这可能是Long,UUID和其他目标类型。如果要允许null要注入,请使用required标志,或声明 argument 作为@Nullable.spring-doc.cadn.net.cn

从 5.3 开始,即使在类型转换后,也将强制执行非空参数。如果您的处理程序 方法也打算接受空值,要么将你的参数声明为@Nullable或将其标记为required=false在相应的@RequestParam等注释。这是 针对 5.3 升级中遇到的回归的最佳做法和建议的解决方案。spring-doc.cadn.net.cn

或者,您可以专门处理,例如,生成的MissingPathVariableException在必需的情况下@PathVariable.转换后的空值将被视为 一个空的原始值,因此相应的Missing…​Exception将抛出变体。spring-doc.cadn.net.cn