gpt4 book ai didi

java - 是否有任何 jackson json 策略(使用注释或其他方式)将在字段反序列化之前和之后执行一些逻辑?

转载 作者:塔克拉玛干 更新时间:2023-11-03 03:23:52 24 4
gpt4 key购买 nike

每次对 POJO 的字段进行反序列化后,我需要执行一些代码。 有什么办法可以通过一些 jackson 注释(或其他)策略来做到这一点?

  1. 解决此问题的一种方法是为每个字段类型创建一个自定义反序列化器,该反序列化器将实现 PostLogicDeserializerInterface 或扩展一些 PostLogicDeserializerAbstract。但这会产生大量难以维护的困惑代码(而不是仅仅使用@JsonProperty)。所以我认为这不是一个好主意。

  2. 我看到您可以在类级别使用 @JsonDeserialize,但只能用于值类。来自文档:

When annotating value classes, configuration is used for instances of the value class but can be overridden by more specific annotations (ones that attach to methods or fields).

所以我认为这也行不通。

  1. 在 POJO setter 方法中使用一些自定义逻辑是一种不好的做法!另一方面,我认为 jackson 无论如何都使用反射来设置字段……这也不是一个好的策略。

我的目标 是确定由反序列化程序设置的字段的百分比。我需要有一个计数器,该计数器会在每次调用反序列化(填充字段)时增加。一旦整个类(POJO)反序列化结束,我就需要使用反射来执行一些逻辑。

现在实现的方式是

  • 一旦 POJO 被 jackson 映射器反序列化,我就使用反射遍历每个字段
  • 检查是否已设置,f.i.如果原始数字为 null 或 -1(以前的初始值)。 (这种方法的一个缺点是您无法检查 boolean 值是否已设置)
  • 将反射用于其他类型的检查(我们称之为逻辑 X)
  • 执行取决于设置字段百分比和逻辑 X 的逻辑。

我更喜欢一些 jackson 策略,因为我不需要用反射来检查 POJO。它宁愿就地完成(在 POJO 被反序列化时)。

干杯,
暴君

最佳答案

此时没有任何特定功能可以进行后处理或预处理;并且这种接近数据绑定(bind)应该做什么的边界。如果我必须针对特定字段执行此操作,我可能只是将其添加到 setter 中,因为这很容易做到并且有效;但在所有相关的 setter 中需要相同的逻辑。

@JsonDeserialize 也可用于单个属性(字段、 setter ),因此您可以创建自定义反序列化器:并且由于您想要进行后处理,您可以定位“真正的”反序列化器(理想情况下通过制作 JsonDeserializer 实现 ContextualDeserializerResolvableDeserializer - 这在这里可能无关紧要,但对于一般情况,它在这里完成是为了避免循环依赖问题),委托(delegate)给它,并修改值。这假设您关心的值(value)超过字段。

最后,还有修改 BeanDeserializer 实例的方法(通过注册 BeanDeserializerModifier)——您可以将相关组件(我认为是 SettableBeanProperty...)子类化为钩入额外的处理,甚至替换要使用的反序列化器,保持对原始“默认”反序列化器的引用。

但最后,您的案例听起来可能最好由其他东西处理:例如 Bean Validation API (jsr-303) 似乎很适合后处理逻辑。由于它在某种程度上与数据绑定(bind)正交,因此它可能是一个更好的替代方案,因为它独立于数据绑定(bind) (jackson),可重用,所有这些好东西。

关于java - 是否有任何 jackson json 策略(使用注释或其他方式)将在字段反序列化之前和之后执行一些逻辑?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5522618/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com