Подтвердить что ты не робот

Джексон: несколько свойств обратной ссылки с именем 'defaultReference'

Я пытаюсь сопоставить json (строковый формат) с объектом, и я получаю следующую ошибку

com.fasterxml.jackson.databind.JsonMappingException: несколько свойства обратной ссылки с именем 'defaultReference'

Это строка json

{"pledge":"74","client":"66","date":"","originId":"1","qualityId":"2","grade":"19","packing":"4","tons":"1000","fromDate":"","toDate":"","type":0,"remark":"","status":0,"area":"1531","id":-1,"refNumber":"","log":"","user":""}

Это объект

@Entity
@Table(name="movement", catalog = "wsmill3")
public class MovementView implements java.io.Serializable {
    private Integer id;
    private Integer originId;
    private Integer qualityId;
    private String refNumber;
    private Integer client;
    private String clientRef;
    private Integer grade;
    private Integer packing;
    private Integer pledge;
    private Integer area;
    private Date date;
    private Double tons;
    private Date fromDate;
    private Date toDate;
    private String remark;
    private User user;
    private Byte status;
    private String log;
    private Byte type;
    //constructor, getter and setter

и это код для отображения

String data = request.getParameter("data");
ObjectMapper mapper = new ObjectMapper();
MovementView movement = mapper.readValue(data, MovementView.class);

Я понятия не имею об этой ошибке, я сделал то же самое, что и на домашней странице Джексона. Любой, кто знает об этом, пожалуйста, помогите мне

4b9b3361

Ответ 1

Если вы используете @JsonBackReference в своем методе getter/setter в своем проекте более двух раз, вы должны отличить их от конкретного ссылочного имени. Возможно, в последней версии разрешено только одно "defaultReference".

например

в MovementView.class

    @JsonBackReference(value="user-movement")
public User getUser() {
    return user;
}

в User.class

    @JsonManagedReference(value="user-movement")
    public User getMovementView() {
    return movementView;
}

Ответ 2

Я также столкнулся с этой проблемой, но решил ее.

//This is parent class
@Entity
@Table(name = "checklist")
@JsonIgnoreProperties("inspection")
public class Checklist implements java.io.Serializable {

    @ManyToOne
    @JoinColumn(name = "product_id", referencedColumnName = "id")
    @JsonBackReference
    private Product product;

    @OneToMany(mappedBy = "checklists", cascade = CascadeType.ALL)
    @JsonManagedReference
    private Set<Inspection> inspection = new HashSet<Inspection>();
//Constructor
//Getter and Setter
}

//This is child class
@Entity
@Table(name = "inspections")
public class Inspection {

    @ManyToOne
    @JoinColumn(name = "chk_id", referencedColumnName = "id")
    private Checklist checklists;
//Constructor
//Getter and Setter
}

Обозначая @JsonIgnoreProperties("inspection") и @JsonManagedReference.

Устранена проблема, вызванная использованием двух @JSONBackRefrence в том же родительском классе.