オブジェクトとしてenumを書き込むジャクソンの設定

When I try to serialize and deserialize a Set of generic objects that look as follows:

public class ClassA {

private ClassB datum;
private T value;
...
}

If that T happens to be an enum, it gets written as a String value. This is fine for serialization, but when I deserialize, it's not possible to know if the String value is an enum or not. Jackson then turns the resulting object into a String and you get a ClassA instead of ClassA.

値がenumであるというヒントを作成するための設定がJacksonにありますか?または、列挙型を文字列値ではなくJSONオブジェクトに変換しますか?

0

1 答え

値がenumであるというヒントを作成するための設定がJacksonにありますか?

一致するJSON文字列値からenumインスタンスに逆シリアル化することは可能です。または、これはどういうわけかあなたの状況には当てはまりませんか?

ここに例があります。

import java.util.Set;
import java.util.TreeSet;

import org.codehaus.jackson.annotate.JsonAutoDetect.Visibility;
import org.codehaus.jackson.annotate.JsonMethod;
import org.codehaus.jackson.map.ObjectMapper;
import org.codehaus.jackson.map.type.TypeFactory;

public class JacksonFoo
{
  public static void main(String[] args) throws Exception
  {
    ObjectMapper mapper = new ObjectMapper().setVisibility(JsonMethod.FIELD, Visibility.ANY);

    String myEnumJson = mapper.writeValueAsString(MyEnum.MyEnum1);

    System.out.println(myEnumJson);

    MyEnum myEnum = mapper.readValue(myEnumJson, MyEnum.class);

    System.out.println(myEnum);

    Set> set = new TreeSet>();
    set.add(new ClassA(new ClassB("bValue7"), MyEnum.MyEnum1));
    set.add(new ClassA(new ClassB("bValue8"), MyEnum.MyEnum2));
    String setJson = mapper.writeValueAsString(set);
    System.out.println(setJson);

    TypeFactory typeFactory = TypeFactory.defaultInstance();

    Set> setCopy = mapper.readValue(setJson,
        typeFactory.constructCollectionType(Set.class,
            typeFactory.constructParametricType(ClassA.class, MyEnum.class)));
    System.out.println(setCopy);
  }
}

class ClassA implements Comparable>
{
  ClassB datum;
  T value;

  ClassA()
  {
  }

  ClassA(ClassB datum, T value)
  {
    this.datum = datum;
    this.value = value;
  }

  @Override
  public int compareTo(ClassA o)
  {
    return 42;
  }

  @Override
  public String toString()
  {
    return String.format("ClassA: datum=%s, value=%s", datum, value);
  }
}

class ClassB
{
  String bValue;

  ClassB()
  {
  }

  ClassB(String bValue)
  {
    this.bValue = bValue;
  }

  @Override
  public String toString()
  {
    return String.format("ClassB: bValue=%s", bValue);
  }
}

enum MyEnum
{
  MyEnum1("myEnum1", 1), MyEnum2("myEnum2", 2);

  String name;
  int id;

  MyEnum(String name, int id)
  {
    this.name = name;
    this.id = id;
  }
}

出力:

"MyEnum1"
MyEnum1
[{"datum":{"bValue":"bValue7"},"value":"MyEnum1"},{"datum":{"bValue":"bValue8"},"value":"MyEnum2"}]
[ClassA: datum=ClassB: bValue=bValue7, value=MyEnum1, ClassA: datum=ClassB: bValue=bValue8, value=MyEnum2]

If for some reason it's necessary to have enums serialized as POJOs, then it appears custom serialization processing is required. Serializing enums with Jackson

1
追加された
関心のある方は、ジャクソンの問題725について議論し、簡単な設定が可能なエンハンスの状態をシリアライズするための可能な拡張を追跡して追跡しました。 jira.codehaus.org/browse/JACKSON-725 あなたがそれを望むなら、投票とコメント。
追加された 著者 Programmer Bruce,
ありがとうBruce、私はtypeFactory.constructCollectionTypeとtypeFactory.constructParametricTypeについて知らなかった。それが私が探していたものです。
追加された 著者 Arthur Maltson,