I have two entities:
Parent { Child[] children; } and Child { Parent parent; }
I'm aware about @JsonBackReference
and @JsonManagedReference
. They are good, if I'm serializing instances of Parent
.
But I also need to transfer instances of Child
and I want to have the parent
field populated.
In other words:
Parent
it should have children
but their parent field might be empty (can be solved by using json reference annotations).Child
it should have parent
with their children
(but children
don't have to have parent
populated.Is there a way to solve it using standard Jackson capabilities?
I.e. skip serialization of entities which were already serialized instead of marking fields eligible or non-eligible for serialization.
Note that Jackson does not use java. io. Serializable for anything: there is no real value for adding that. It gets ignored.
The @JsonManagedReference annotation is a forward reference that includes during the serialization process whereas @JsonBackReference annotation is a backreference that omits during the serialization process. In the below example, we can implement @JsonManagedReference and @JsonBackReference annotations.
@JsonBackReference is the back part of reference – it will be omitted from serialization. The serialized Item object does not contain a reference to the User object.
Jackson is a solid and mature JSON serialization/deserialization library for Java. The ObjectMapper API provides a straightforward way to parse and generate JSON response objects with a lot of flexibility.
Jackson 2.0 does support full cyclic object references. See "Jackson 2.0 released" (section 'Handle Any Object Graphs, even Cyclic ones!') for an example.
Basically, you will need to use new @JsonIdentityInfo
for types that require id/idref style handling. In your case this would be both Parent
and Child
types (if one extends the other, just add it to super type and that's fine).
very handy interface implementation is provided in jackson 2 library as
@Entity @JsonIdentityInfo(generator=ObjectIdGenerators.PropertyGenerator.class, property="id") public class Parent { .... @Entity @JsonIdentityInfo(generator=ObjectIdGenerators.PropertyGenerator.class, property="id") public class Child { ....
in maven
<dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> <version>2.0.2</version> </dependency>
@StaxMan provided a nice link to start from
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With