Serialization 将枚举作为对象写入的Jackson配置

Serialization 将枚举作为对象写入的Jackson配置,serialization,enums,deserialization,jackson,Serialization,Enums,Deserialization,Jackson,当我尝试序列化和反序列化集时 Jackson中是否有配置让它创建一些提示,表明该值是枚举 可以从匹配的JSON字符串值反序列化到枚举实例。或者这不适合你的情况 这里有一个例子 import java.util.Set; import java.util.TreeSet; import org.codehaus.jackson.annotate.JsonAutoDetect.Visibility; import org.codehaus.jackson.annotate.JsonMethod;

当我尝试序列化和反序列化
集时
Jackson中是否有配置让它创建一些提示,表明该值是枚举

可以从匹配的JSON字符串值反序列化到枚举实例。或者这不适合你的情况

这里有一个例子

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<ClassA<MyEnum>> set = new TreeSet<ClassA<MyEnum>>();
    set.add(new ClassA<MyEnum>(new ClassB("bValue7"), MyEnum.MyEnum1));
    set.add(new ClassA<MyEnum>(new ClassB("bValue8"), MyEnum.MyEnum2));
    String setJson = mapper.writeValueAsString(set);
    System.out.println(setJson);

    TypeFactory typeFactory = TypeFactory.defaultInstance();

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

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

  ClassA()
  {
  }

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

  @Override
  public int compareTo(ClassA<T> 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;
  }
}
如果出于某种原因有必要将枚举序列化为POJO,那么似乎需要自定义序列化处理

Jackson中是否有配置让它创建一些提示,表明该值是枚举

可以从匹配的JSON字符串值反序列化到枚举实例。或者这不适合你的情况

这里有一个例子

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<ClassA<MyEnum>> set = new TreeSet<ClassA<MyEnum>>();
    set.add(new ClassA<MyEnum>(new ClassB("bValue7"), MyEnum.MyEnum1));
    set.add(new ClassA<MyEnum>(new ClassB("bValue8"), MyEnum.MyEnum2));
    String setJson = mapper.writeValueAsString(set);
    System.out.println(setJson);

    TypeFactory typeFactory = TypeFactory.defaultInstance();

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

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

  ClassA()
  {
  }

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

  @Override
  public int compareTo(ClassA<T> 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;
  }
}

如果出于某种原因有必要将枚举序列化为POJO,那么似乎需要自定义序列化处理

对于感兴趣的人,我记录了Jackson第725期,以讨论和跟踪一种可能的增强功能,以便轻松配置(反)序列化枚举的状态。如果需要,请投票并发表评论。谢谢Bruce,我不知道typeFactory.ConstructionCollectionType和typeFactory.ConstructionParameterType。这就是我一直在寻找的。对于感兴趣的人,我记录了Jackson第725期,讨论并跟踪一个可能的增强功能,以便于配置(反)序列化枚举的状态。如果需要,请投票并发表评论。谢谢Bruce,我不知道typeFactory.ConstructionCollectionType和typeFactory.ConstructionParameterType。这就是我要找的。
"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]