首页 >Java >有没有办法将 Java 枚举与 YAML 进行(反)序列化?

有没有办法将 Java 枚举与 YAML 进行(反)序列化?

WBOY
WBOY转载
2024-02-08 22:15:18969浏览

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中文网其他相关文章!

声明:
本文转载于:stackoverflow.com。如有侵权,请联系admin@php.cn删除