gpt4 book ai didi

java - 使 Spring Boot JSON 枚举反序列化严格,因此它不会默默地将无效值转换为 null

转载 作者:行者123 更新时间:2023-12-02 02:26:07 34 4
gpt4 key购买 nike

我正在使用 Java Spring Boot @RestController 和一个包含枚举字段的对象。Spring 自动将 JSON 反序列化为 MyRequest 对象。

@RestController
public class MyController {
@PostMapping(path = "/operation")
public ResponseEntity<MyResponse> operation(@Valid @RequestBody MyRequest request) {
...
}
}

public class MyRequest {
private MyEnum1 field1;
private MyEnum2 field2;
private MyEnum3 field3;
private MyEnum4 field4;
private MyEnum5 field5;
private MyEnum6 field6;
... // really a lot of various enum fields!
}

public enum MyEnum1 {
VAL1, VAL2, VAL3;
}

问题是,如果 JSON 包含 enum 字段的完全无效值,反序列化器会无一异常(exception)地将它们无提示地转换为 null

{
"field1": "BLAHBLAH",
...
}

这是对用户不友好且背信弃义的。

我知道我可以为每个枚举编写自定义 JSON 反序列化器,但该解决方案既麻烦又不优雅。

有没有办法将 JSON 枚举反序列化器全局设置为“严格模式”,这样如果值无效就会抛出异常?如果是,如何以及在哪里?

最佳答案

默认情况下应禁用该功能。

但是如果你想明确地设置它,你可以这样做:

在您的属性中:

spring.jackson.deserialization.read-unknown-enum-values-as-null=false

或者作为配置类中的替代方案(实际上任何 bean 都可以工作,只要确保它尽早发生):

@Autowired
public void configureJackson(ObjectMapper objectMapper) {
objectMapper.disable(DeserializationFeature.READ_UNKNOWN_ENUM_VALUES_AS_NULL);
}

因为默认情况下它实际上应该是这样的,我想知道为什么它不适合你。你在某处启用它吗?您使用的是哪个 Spring Boot 版本?

关于java - 使 Spring Boot JSON 枚举反序列化严格,因此它不会默默地将无效值转换为 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65630241/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com