我有以下实体:
@Entity
@Table(name = "registry_entry")
@JsonIgnoreProperties(ignoreUnknown = true)
public class RegistryEntry extends GenericEntity {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(unique = true, nullable = false)
@JsonProperty("id")
protected Long id;
...
@ManyToMany(fetch = FetchType.EAGER)
@JoinTable(name = "srv_registry_entry_related_dependence",
joinColumns = @JoinColumn(name = "id_reg_entry", referencedColumnName = "id"),
inverseJoinColumns = @JoinColumn(name = "id_related_reg_entry", referencedColumnName = "id"))
@JsonProperty
private List<RegistryEntry> relatedRegistryEntries;
...
}
假设我们有实体A
and B
where B.relatedRegistryEntries
包含A
and A.relatedRegistryEntries
包含B
.
当我尝试序列化时A
or B
, i get StackOverflowError
。我怎样才能只序列化这个列表中的id?
杰克逊支持@JsonIdentityInfo。这就是您所描述的:将此注释添加到类将使该类的所有实例都使用附加 ID 字段进行序列化,并且下次需要序列化同一实例时,将写入该 ID 字段的值而不是整个对象。
但请注意,这不是标准 JSON。一般来说,通常使用 JSON 格式,因为它受到许多库的广泛支持。使用此功能可能会给您的 API 客户端带来更多问题。
更普遍兼容的方法是序列化自引用对象而不带其自引用字段:
public class RegistryEntry {
@JsonIgnoreProperties("relatedRegistryEntries")
private List<RegistryEntry> relatedRegistryEntries;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)