Jackson 的 JsonManagedReference 和 JsonBackReference 注解
在 Hibernate 或者 ORM 映射中,我们可能会存在 1 对多的情况。
在这个时候,如果你使用 Jackson 将对象序列化的时候,就会出现双向引用导致的无限递归(infinite recursion)的情况。
@JsonManagedReference 和 @JsonBackReference 注解就是为了避免这个双向引用的情况。
@JsonBackReference 和 @JsonManagedReference:这两个标注通常配对使用,通常用在父子关系中。
假设我们有 2 个对象。
一个对象是 QIndex 和 QTitle
一个 QIndex 可能对应有多个 QTitle。
那么在 JPA 中的对应关系的 QIndex 应该定义为:
@OneToMany(mappedBy = "qIndex", cascade = CascadeType.ALL, orphanRemoval = true)
@OrderBy("questionNumber ASC")
@JsonManagedReference
private List<QTitle> qTitleList = new ArrayList<>();
在 JPA 的 QTitle 中应该定义为:
@ManyToOne()
@JsonBackReference
private QIndex qIndex;
在序列化的时候,@JsonManagedReference 注解的属性则会被序列化,@JsonBackReference 的注解将会被忽略。
@JsonManagedReference 注解,通常说明这个字段是一个双向引用的字段,这个字段在这个双向引用中的角色为 “父”,与这个字段对应的引用需要注解为 @JsonBackReference。
@JsonBackReference 注解,通常说明这个字段是关联的一个双向引用字段,这个字段在这个双向引用的角色是 “孩子”。这个字段的值只能是对象(Bean),不能是 集合(Collection),图(Map),数组(Array)和枚举类型(enumeration)。
总结
- @JsonManagedReference 和 @JsonBackReference 总是成对出现的
- @JsonManagedReference 定义在父级角色
- @JsonBackReference 定义在孩子级角色
- @JsonBackReference 不能使用任何集合和数组等多的数据结构
有了上面的解释,应该比较容易的理解为了避免双向引用导致无限递归而出现的问题的。
https://www.ossez.com/t/jackson-jsonmanagedreference-jsonbackreference/574
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
2018-10-11 Confluence 6 针对站点维护使用只读模式
2018-10-11 Confluence 6 协同编辑问题解决