Спящий рекурсивный ответ Json
Я сопоставляю две таблицы базы данных в двух объектах java, используя hibernate. Вместо представления внешних ключей таблиц с атрибутом в Java я использую аннотации hibernate @OneToMany и @ManyToMany. Проблема в том, что когда я хочу получить список объектов Json, я получаю рекурсивные отношения.
Вот "родительский" объект Cliente.java
@Entity @Table(name="clienti")
@AllArgsConstructor @NoArgsConstructor @Data
public class Cliente {
@Id @Column(name="idcliente") @NotBlank
private String idCliente;
@Column(name="ragionesociale")
private String ragioneSociale;
@Column(name="nominativo") @NotBlank
private String nominativo;
@Column(name="indirizzo")
private String indirizzo;
@Column(name="telefono")
private String telefono;
@Column(name="email")
private String email;
@Column(name="sito")
private String sito;
@Column(name="segnalatore")
private String segnalatore;
@Column(name="attivita")
private String attivita;
@Column(name="interessatoa")
private String interessatoA;
@OneToMany(mappedBy="cliente")
private List<Pratica> pratiche;
@Column(name="registratoda")
private String registratoDa;
@Column(name="data")
private Date data;
@Column(name="note")
private String note;
@PrePersist
private void salvaData(){
data = new Date();
}
}
Этот объект имеет список, который является списком дочерних объектов. Теперь класс Pratica.java:
@Entity @Table(name="pratiche")
@AllArgsConstructor@NoArgsConstructor @lombok.Data
public class Pratica {
@Id @Column(name="idpratica")
private String idPratica;
@Column(name="descrizione")
private String descrizione;
@Column(name="note")
private String note;
@Column(name="data")
private Date data;
@ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name="idcliente", nullable=false)
private Cliente cliente;
@Column(name="registratoDa")
private String registratoDa;
@PrePersist
private void setCampi(){
data = new Date();
idPratica = data.toInstant().toString() + cliente.getIdCliente();
}
}
Я сохранил некоторые объекты Cliente и Pratica, используя мой Daos:
//******
clienteDao.save(new Cliente("IDCLIENTE_1", "RAGIONESOCIALE_1", "NOMINATIVO_1", "INDIRIZZO_1", "TELEFONO_1", "EMAIL_1", "SITO_1", "SEGNALATORE_1", "ATTIVITA_1", "INTERESSATOA_1", null, "RGNLSN87H13D761R", null, "NOTE_1"));
clienteDao.save(new Cliente("IDCLIENTE_2", "RAGIONESOCIALE_2", "NOMINATIVO_2", "INDIRIZZO_2", "TELEFONO_2", "EMAIL_2", "SITO_2", "SEGNALATORE_2", "ATTIVITA_2", "INTERESSATOA_2", null, "RGNLSN87H13D761R", null, "NOTE_2"));
clienteDao.save(new Cliente("IDCLIENTE_3", "RAGIONESOCIALE_3", "NOMINATIVO_3", "INDIRIZZO_3", "TELEFONO_3", "EMAIL_3", "SITO_3", "SEGNALATORE_3", "ATTIVITA_3", "INTERESSATOA_3", null, "RGNLSN8UTED761R", null, "NOTE_3"));
//******
praticaDao.save(new Pratica("IDPRATICA_1", "DESCRIZIONE_1", null, "NOTE_1", null, clienteDao.getOne("IDCLIENTE_1"), "RGNDCN8DUYD761R"));
praticaDao.save(new Pratica("IDPRATICA_2", "DESCRIZIONE_2", null, "NOTE_2", null, clienteDao.getOne("IDCLIENTE_1"), "RGNLS32H13D761R"));
praticaDao.save(new Pratica("IDPRATICA_3", "DESCRIZIONE_3", null, "NOTE_3", null, clienteDao.getOne("IDCLIENTE_2"), "RGNLKIU87H13D761R"));
praticaDao.save(new Pratica("IDPRATICA_4", "DESCRIZIONE_4", null, "NOTE_4", null, clienteDao.getOne("IDCLIENTE_2"), "RGNTGH7H13D761R"));
praticaDao.save(new Pratica("IDPRATICA_5", "DESCRIZIONE_5", null, "NOTE_5", null, clienteDao.getOne("IDCLIENTE_3"), "RGNLGTR13D761R"));
praticaDao.save(new Pratica("IDPRATICA_6", "DESCRIZIONE_6", null, "NOTE_6", null, clienteDao.getOne("IDCLIENTE_3"), "RGNLSNHYDFR3D761R"));
Но когда я хочу получить список или список в формате JSON, я получаю рекурсивные отношения.
[{"idCliente":"IDCLIENTE_1","ragioneSociale":"RAGIONESOCIALE_1","nominativo":"NOMINATIVO_1","indirizzo":"INDIRIZZO_1","telefono":"TELEFONO_1","email":"EMAIL_1","sito":"SITO_1","segnalatore":"SEGNALATORE_1","attivita":"ATTIVITA_1","interessatoA":"INTERESSATOA_1","pratiche":[{"idPratica":"2018-03-21T21:27:05.582ZIDCLIENTE_1","descrizione":"DESCRIZIONE_1","documenti":[],"note":"NOTE_1","data":"2018-03-21T21:27:05.582+0000","cliente":{"idCliente":"IDCLIENTE_1","ragioneSociale":"RAGIONESOCIALE_1","nominativo":"NOMINATIVO_1","indirizzo":"INDIRIZZO_1","telefono":"TELEFONO_1","email":"EMAIL_1","sito":"SITO_1","segnalatore":"SEGNALATORE_1","attivita":"ATTIVITA_1","interessatoA":"INTERESSATOA_1","pratiche":[{"idPratica":"2018-03-21T21:27:05.582ZIDCLIENTE_1","descrizione":"DESCRIZIONE_1","documenti":[],"note":"NOTE_1","data":"2018-03-21T21:27:05.582+0000","cliente":{"idCliente":"IDCLIENTE_1","ragioneSociale":"RAGIONESOCIALE_1","nominativo":"NOMINATIVO_1","indirizzo":"INDIRIZZO_1","telefono":"TELEFONO_1","email":"EMAIL_1","sito":"SITO_1","segnalatore":"SEGNALATORE_1","attivita":"ATTIVITA_1","interessatoA":"INTERESSATOA_1","pratiche":[{"idPratica":"2018-03-21T21:27:05.582ZIDCLIENTE_1","descrizione":"DESCRIZIONE_1","documenti":[],"note":"NOTE_1","data":"2018-03-21T21:27:05.582+0000","cliente":{"idCliente":"IDCLIENTE_1","ragioneSociale":"RAGIONESOCIALE_1","nominativo":"NOMINATIVO_1","indirizzo":"INDIRIZZO_1","telefono":"TELEFONO_1","email":"EMAIL_1","sito":"SITO_1","segnalatore":"SEGNALATORE_1","attivita":"ATTIVITA_1","interessatoA":"INTERESSATOA_1","pratiche":[{"idPratica":"2018-03-21T21:27:05.582ZIDCLIENTE_1","descrizione":"DESCRIZIONE_1","documenti":[],"note":"NOTE_1","data":"2018-03-21T21:27:05.582+0000","cliente":{"idCliente":"IDCLIENTE_1","ragioneSociale":"RAGIONESOCIALE_1","nominativo":"NOMINATIVO_1","indirizzo":"INDIRIZZO_1","telefono":"TELEFONO_1","email":"EMAIL_1","sito":"SITO_1","segnalatore":"SEGNALATORE_1","attivita":"ATTIVITA_1","interessatoA":"INTERESSATOA_1","pratiche":[{"idPratica":"2018-03-21T21:27:05.582ZIDCLIENTE_1","descrizione":"DESCRIZIONE_1","documenti":[],"note":"NOTE_1","data":"2018-03-21T21:27:05.582+0000","cliente":{"idCliente":"IDCLIENTE_1","ragioneSociale":"RAGIONESOCIALE_1","nominativo":"NOMINATIVO_1","indirizzo":"INDIRIZZO_1","telefono":"TELEFONO_1","email":"EMAIL_1","sito":"SITO_1","segnalatore":"SEGNALATORE_1","attivita":"ATTIVITA_1","interessatoA":"INTERESSATOA_1","pratiche":[{"idPratica":"2018-03-...
Есть ли ошибка в аннотациях или это нормально, используя @OneToMany и @ManyToOne, и есть способ получить лучший JSON, который лучше отображает таблицу?
1 ответ
Благодаря SY Wang это дубликат Infinite Recursion с выпуском Jackson JSON и Hibernate JPA
Таким образом, способ решить эту рекурсию - использовать две аннотации:
@JsonManagedReference
близко к аннотации @OneToMany в родительском объекте и
@JsonBackReference
близко к аннотации @ManyToOne в дочернем объекте, чтобы заблокировать рекурсию при использовании JacksonLibrary.