The @JsonManagedReference และ @JsonBackReference คำอธิบายประกอบ สามารถใช้เพื่อสร้างโครงสร้าง JSON ใน แบบสองทิศทาง ทาง. @JsonManagedReference คำอธิบายประกอบคือการอ้างอิงไปข้างหน้า ซึ่งรวมถึงในระหว่างกระบวนการทำให้เป็นอันดับในขณะที่ @JsonBackReference คำอธิบายประกอบเป็น การอ้างอิงย้อนกลับ ที่ละเว้นในระหว่างขั้นตอนการทำให้เป็นอนุกรม
ในตัวอย่างด้านล่าง เราสามารถใช้คำอธิบายประกอบ @JsonManagedReference และ @JsonBackReference
ตัวอย่าง
import java.util.*;
import com.fasterxml.jackson.annotation.JsonManagedReference;
import com.fasterxml.jackson.annotation.JsonBackReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.core.JsonProcessingException;
public class ManagedReferenceBackReferenceTest {
public static void main(String args[]) throws JsonProcessingException {
BackReferenceBeanTest testBean = new BackReferenceBeanTest(110, "Sai Chaitanya");
ManagedReferenceBeanTest bean = new ManagedReferenceBeanTest(135, "Adithya Ram", testBean);
testBean.addEmployees(bean);
ObjectMapper mapper = new ObjectMapper();
String jsonString = mapper.writerWithDefaultPrettyPrinter().writeValueAsString(bean);
System.out.println(jsonString);
}
}
class ManagedReferenceBeanTest {
public int empId = 115;
public String empName = "Raja Ramesh";
@JsonManagedReference
public BackReferenceBeanTest manager;
public ManagedReferenceBeanTest(int empId, String empName, BackReferenceBeanTest manager) {
this.empId = empId;
this.empName = empName;
this.manager = manager;
}
}
class BackReferenceBeanTest {
public int empId = 125;
public String empName = "Jai Dev";
@JsonBackReference
public List<ManagedReferenceBeanTest> list;
public BackReferenceBeanTest(int empId, String empName) {
this.empId = empId;
this.empName = empName;
list = new ArrayList<ManagedReferenceBeanTest>();
}
public void addEmployees(ManagedReferenceBeanTest managedReferenceBeanTest) {
list.add(managedReferenceBeanTest);
}
} ผลลัพธ์
{
"empId" : 135,
"empName" : "Adithya Ram",
"manager" : {
"empId" : 110,
"empName" : "Sai Chaitanya"
}
}