我试图写一个自定义的解析器,以削减我从其他地方收到的一大组数据。我从解析器返回一个自定义对象的列表。
我的问题是,我如何做到这一点,如果这是我的自定义编译器:
public class MyCustomDeserializer extends JsonDeserializer<List<CustomClass>> { ... }
字符串
我当然不能这么做:
final SimpleModule module = new SimpleModule();
module.addDeserializer(List<CustomClass>.class, new MyCustomDeserializer());
型
这样的东西会工作吗?
final List<CustomClass> response = Arrays.asList(objectMapper.readValue(stringBean, CustomClass[].class));
型
如果这确实有效,我会发现它有点令人困惑和“危险”?不是在asList方法调用中完成了非线性化吗?所以它基本上是将ListMap到数组[]?
我学习了TypeReference,所以我可以这样使用它:
objectMapper.readValue(stringBean, new TypeReference<List<CustomClass>>(){});
型
但我听说比较慢。
我也不想为列表创建一个容器,并在容器化中返回它,因为这意味着它将被 Package 在另一个json对象中,我只想让我的端点产生这样的东西:
[{object1}, {object2}]
// instead of
{"Output" : [{object1}, {object2}]}
型
编辑:
看来我误解了Jackson在这两种情况下是如何使用我的验证器的:
final List<CustomClass> response = Arrays.asList(objectMapper.readValue(stringBean, CustomClass[].class));
// or
objectMapper.readValue(stringBean, new TypeReference<List<CustomClass>>(){});
型
它看起来像是一个数组中的每个对象都被调用了两次。我以为整个数组将被视为一个整体。为了消除混淆,我的意思是:
我接收并尝试实现的json看起来像这样:
[
{
"Data" : {
"id" : "someId",
"otherThing" : "someOtherThing"
},
"Message" : "OK"
},
{
"Data" : null,
"Message" : "Object not found for id blabla"
}
]
型
所以我认为这是我在我的验证器中应该有的,但正如我之前所说的,似乎我实际上从该数组中获取每个“条目”,并多次调用它。
3条答案
按热度按时间ujv3wf0j1#
首先,如果你在bean
CustomClass
上使用annotation注册了你的自定义解析器,那么解析器应该处理CustomClass
的一个示例,而不是一个集合,因此应该定义:字符串
现在可以使用Jackson的类型工厂向Map器传递所需的类型信息
型
23c0lvtd2#
我通过向模型类中的一个属性添加一个自定义的解析器并使用JsonObjectualize annotation的
contentUsing()
方法来解决这个问题,如下所示:字符串
其中MyCustomDataizer类是自定义的JacksonJSON Dataizer,定义为:
型
wlzqhblo3#
这两条线就足够了。
字符串
以后再谢我!