jackson – 反序列化一个基础枚举

是否可以反序列化具有一个索引的枚举?

enum Status { Active, Inactive } 

{status:1}表示Status.Active,但Jackson使其成为Status.Inactive 🙁

您可以为枚举创建自定义类型反序列化器:

 public enum Status { ACTIVE, INACTIVE; public static Status fromTypeCode(final int typeCode) { switch(typeCode) { case 1: return ACTIVE; case 2: return INACTIVE; } throw new IllegalArgumentException("Invalid Status type code: " + typeCode); } } public class StatusDeserializer extends JsonDeserializer { @Override public Status deserialize(final JsonParser parser, final DeserializationContext context) throws IOException { return Status.fromTypeCode(parser.getValueAsInt()); } } 

然后,您可以告诉Jackson使用您的自定义deserialiser作为属性:

 public class WarpDrive { private Status status; @JsonDeserialize(using = StatusDeserializer.class) public void setStatus(final Status status) { this.status = status; } public Status getStatus() { return this.status; } } 

您还可以配置Jackson对象映射器,以便为所有出现的目标类型使用自定义反序列化器。 请参阅http://wiki.fasterxml.com/JacksonHowToCustomDeserializers 。

 public enum Status { ACTIVE(1), INACTIVE(2); private final int value; Status(int v) { value = v; } @org.codehaus.jackson.annotate.JsonValue public int value() { return value; } @org.codehaus.jackson.annotate.JsonCreator public static Status fromValue(int typeCode) { for (Status c: Status.values()) { if (c.value==typeCode) { return c; } } throw new IllegalArgumentException("Invalid Status type code: " + typeCode); }} 

枚举具有数字序数 ,从零开始,并按照声明的顺序分配给枚举中的每个值。 例如,在您的代码中, Active有序号0Inactive有序号1 。 您可以在枚举值与其序数之间来回切换,如下所示:

 // ordinal=0, since Active was declared first in the enum int ordinal = Status.Active.ordinal(); // enumVal=Active, since 0 is the ordinal corresponding to Active Status enumVal = Status.values()[0]; 

显然,序数1对应于Inactive (它不是jackson问题),如上所述,枚举中的序数是从零开始的。 也许您应该修改代码以反映这一点,并确保{status:0}表示Status.Active