欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

有办法用 YAML 对 Java 枚举进行(去)序列化吗?

最编程 2024-04-22 13:01:53
...

php小编草莓回答:是的,有办法将 java 枚举与 yaml 进行序列化与反序列化。java 枚举可以通过使用 jackson、gson 或其他 json 库来实现序列化和反序列化。yaml 是一种人类友好的数据格式,也可以通过 jackson、snakeyaml 或其他 yaml 库来实现与 java 枚举的序列化和反序列化。使用这些库,可以轻松地将 java 枚举与 yaml 进行转换,实现数据的传输和存储。

问题内容

我正在尝试序列化和反序列化一个包含枚举到/来自 YAML 表示的 Java 对象。我正在尝试使用 Jackson (com.fasterxml.jackson) 包来执行此操作。

我不断收到此异常:

Caused by: com.fasterxml.jackson.databind.exc.InvalidFormatException: Cannot deserialize value of type `com.beastcode.devops.prometheusbroker.domain.Metric$Type` from String "counter": not one of the values accepted for Enum class: [GAUGE, COUNTER]
登录后复制

我假设我需要某种适配器或转换器,但不知道 YAML 有什么可用(如果有的话)。

供参考:

Metric.java:

public class Metric {

  public enum Type {
    COUNTER, GAUGE
  }

  private String           name;
  private String           description;
  private Type             type;
  private List<String>     labels;
  private List<MetricData> data;

  // getters/setters removed
}
登录后复制

数据.yaml:

---
name: gitlab_pipeline_success_total
description: "blah blah blah"
type: counter
labels:
  - project
  - somethingElse
data:
登录后复制

解析器.java:

public class Parser {

  private ObjectMapper mapper = new ObjectMapper(new YAMLFactory());

  public void parse() throws StreamReadException, DatabindException, IOException {
    Metric m = mapper.readValue(new File("data.yaml"), Metric.class);
  }

}
登录后复制

解决方法

默认情况下,Jackson 使用枚举的 valueOf 方法。区分大小写。

您可以通过添加用 @JsonCreator 注释的静态方法来轻松更改此设置:

public class Metric {

    public enum Type {
        COUNTER, GAUGE;

        @JsonCreator
        public static Type getType(String value) {
            return valueOf(value.toUpperCase());
        }

        // optional, for serialization
        @JsonValue
        public String value() {
            return name().toLowerCase();
        }
    }

    // rest omitted
}
登录后复制

以上就是有没有办法将 Java 枚举与 YAML 进行(反)序列化?的详细内容,更多请关注php中文网其它相关文章!