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