我需要使用Jackson将JSON字符串反序列化为不同对象类型的列表,具体取决于在其中一个字段中设置的值。我想知道创建不同列表类型的最佳方法,以及我如何实现这一点?Jackson根据字符串值反序列化JSON到不同类型列表
我的JSON的会是这个样子:
{"test":
{"conditions":[....],
"consequence": {"actionType":"string",
"action": ["value 1","value 2"]}
}
}
所以分析时,上面会返回一个List
{"test":
{"conditions":[....],
"consequence": {"actionType":"test",
"action": ["test","test"]}
}
}
和上面会返回一个List
我的POJO的只包含:
@Data
public class Consequence {
public Consequence(String actionType){
this.actionType = actionType;
};
@JsonProperty("ACTIONTYPE")
private String actionType;
@JsonProperty("ACTION")
private List???> action;
}
UPDATE:
@Data
public abstract class BaseConsequence {
public BaseConsequence(String actionType){
this.actionType = actionType;
};
@JsonProperty("ACTIONTYPE")
private String actionType;
}
@Data
@DiscriminatorValue(value = "CONCATENATE")
public class ConcatenateConsequence extends BaseConsequence {
public ConcatenateConsequence(String actionType, List concatenateValues) {
super(actionType);
this.concatenateValues = concatenateValues;
}
private List concatenateValues;
}
@Data
@DiscriminatorValue(value = "test")
public class TestConsequence extends BaseConsequence {
public TestConsequence(String actionType, List tests){
super(actionType);
this.tests = tests;
}
private List tests;
}
@Data
public class Test {
public Test(){};
public Test(List conditions, BaseConsequence baseConsequence){
this.conditions = conditions;
this.baseConsequence = baseConsequence;
}
@JsonProperty("CONDITIONS")
private List conditions;
@JsonProperty("CONSEQUENCE")
private BaseConsequence baseConsequence;
@Override
public boolean equals(Object o) {
if (o == this) return true;
if (!(o instanceof Test)) {
return false;
}
Test test = (Test) o;
return Objects.equals(conditions, test.conditions) && Objects.equals(baseConsequence, test.baseConsequence);
}
@Override
public int hashCode() {
return Objects.hash(conditions, baseConsequence);
}
}
我收到以下错误:
com.fasterxml.jackson.databind.JsonMappingException: Can not deserialize instance of java.util.ArrayList out of START_OBJECT token
at [Source: {"TEST":{"CONDITIONS":[{"KEY":"KEY1","VALUES":["FLOAT"],"OPERATOR":""}],"CONSEQUENCE":{"ACTIONTYPE" :{"CONCATENATE": ["VALUE1","VALUE2"]}}}}; line: 1, column: 9] (through reference chain: package.TestCase["TEST"])
2017-09-25
Orby