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 = ?

有人知道是否有一个魔法命令缺失了吗?如果不是,那么解决方案是什么?


当前回答

试试这个

List<MyClass> list = mapper.readerForListOf(MyClass.class).readValue(json)

其他回答

你也可以创建一个继承ArrayList的类:

ArrayList<Myclass>}

然后像这样使用它:

List<MyClass> list = objectMapper.readValue(json, MyList.class);

我无法使用这个答案,因为我的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;
}
try {
    ObjectMapper mapper = new ObjectMapper();
    JsonFactory f = new JsonFactory();
    List<User> lstUser = null;
    JsonParser jp = f.createJsonParser(new File("C:\\maven\\user.json"));
    TypeReference<List<User>> tRef = new TypeReference<List<User>>() {};
    lstUser = mapper.readValue(jp, tRef);
    for (User user : lstUser) {
        System.out.println(user.toString());
    }

} catch (JsonGenerationException e) {
    e.printStackTrace();
} catch (JsonMappingException e) {
    e.printStackTrace();
} catch (IOException e) {
    e.printStackTrace();
}

试试这个

List<MyClass> list = mapper.readerForListOf(MyClass.class).readValue(json)

首先创建一个线程安全的ObjectReader实例。

ObjectMapper objectMapper = new ObjectMapper();
ObjectReader objectReader = objectMapper.reader().forType(new TypeReference<List<MyClass>>(){});

然后使用它:

List<MyClass> result = objectReader.readValue(inputStream);