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" } }