Jackson数据绑定文档指出Jackson支持反序列化“所有受支持类型的数组”,但我不知道它的确切语法。
对于单个对象,我会这样做:
//json input
{
"id" : "junk",
"stuff" : "things"
}
//Java
MyClass instance = objectMapper.readValue(json, MyClass.class);
现在对于一个数组,我想这样做:
//json input
[{
"id" : "junk",
"stuff" : "things"
},
{
"id" : "spam",
"stuff" : "eggs"
}]
//Java
List<MyClass> entries = ?
有人知道是否有一个魔法命令缺失了吗?如果不是,那么解决方案是什么?
我无法使用这个答案,因为我的linter不允许未检查的强制转换。
这里有一个你可以使用的替代方案。我觉得这实际上是一个更干净的解决方案。
public <T> List<T> parseJsonArray(String json, Class<T> clazz) throws JsonProcessingException {
var tree = objectMapper.readTree(json);
var list = new ArrayList<T>();
for (JsonNode jsonNode : tree) {
list.add(objectMapper.treeToValue(jsonNode, clazz));
}
return list;
}
我无法使用这个答案,因为我的linter不允许未检查的强制转换。
这里有一个你可以使用的替代方案。我觉得这实际上是一个更干净的解决方案。
public <T> List<T> parseJsonArray(String json, Class<T> clazz) throws JsonProcessingException {
var tree = objectMapper.readTree(json);
var list = new ArrayList<T>();
for (JsonNode jsonNode : tree) {
list.add(objectMapper.treeToValue(jsonNode, clazz));
}
return list;
}
首先创建一个映射器:
import com.fasterxml.jackson.databind.ObjectMapper;// in play 2.3
ObjectMapper mapper = new ObjectMapper();
数组:
MyClass[] myObjects = mapper.readValue(json, MyClass[].class);
正如列表:
List<MyClass> myObjects = mapper.readValue(jsonInput, new TypeReference<List<MyClass>>(){});
另一种指定List类型的方法:
List<MyClass> myObjects = mapper.readValue(jsonInput, mapper.getTypeFactory().constructCollectionType(List.class, MyClass.class));