Как десериализовать из числового значения в int (ошибка - нет конструктора int / Int-аргумента / фабричного метода для десериализации из числового значения) - PullRequest
0 голосов
/ 17 декабря 2018

У меня есть два класса Flight и Ticket.У одного рейса может быть много билетов, поэтому Ticket имеет внешний ключ flight_id.

Вот моя база данных с таблицами flight и ticket.

enter image description here

Вот мой json request (из отладчика Mozilla), который я хочу сохранить в базе данных.

enter image description here

Вы можете видеть параметр flight_id, но я не могу сохранить его в своей базе данных, у меня такая ошибка:

at [Source: (PushbackInputStream); line: 1, column: 53] (through reference chain: dto.TicketDto["flight_id"]) DefaultHandlerExceptionResolver : Failed to read HTTP message: org.springframework.http.converter.HttpMessageNotReadableException: JSON parse error: Cannot construct instance of model.Flight (although at least one Creator exists): no int/Int-argument constructor/factory method to deserialize from Number value (199); nested exception is com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot construct instance of model.Flight (although at least one Creator exists): no int/Int-argument constructor/factory method to deserialize from Number value

Классный билет:

@Entity
@Table(name = "ticket")
public class Ticket {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int ticket_id;

@Column(name = "place")
private int place;

@Column(name = "name")
private String name;

@Column(name = "surname")
private String surname;

@JsonDeserialize(using = CustomParameterDeserializer.class)
@ManyToOne(targetEntity = Flight.class)
@JoinColumn(name = "flight_id")
@JsonBackReference("flight")
private Flight flight_id;

// getters setters
// constructor

Классный билетDto:

public class TicketDto {

private int ticket_id;

private int place;

private String name;

private String surname;

private Flight flight_id;

private Customer customer_id;

// getters setters

Мой класс Flight:

@Entity
@Table(name = "flight")
public class Flight {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int flight_id;

//

@OneToMany(mappedBy = "flight_id")
@JsonManagedReference("flight")
private List<Ticket> ticket;

// getters setters

Мой класс FlightDto:

public class FlightDto {
private int flight_id;

//

private List<TicketDto> ticket;

// getters setters

Вот класс TicketServiceImpl с методом сохранения моего билета:

@Service
public class TicketServiceImpl implements TicketService {

@Autowired
TicketRepository repository;

@Override
public Ticket save(TicketDto ticketDto) {
    Ticket ticket = new Ticket();
    ticket.setName(ticketDto.getName());
    ticket.setSurname(ticketDto.getSurname());
    ticket.setCustomer_id(ticketDto.getCustomer_id());
    ticket.setFlight_id(ticketDto.getFlight_id());
    ticket.setPlace(ticketDto.getPlace());

    return repository.save(ticket);
}

Мой класс ticket.ts в Angular:

export class Ticket {
ticket_id: number;
place: string;
customer_id: number;
flight_id: number;
name: string;
surname: string;
}

Ответы [ 2 ]

0 голосов
/ 17 декабря 2018

Ожидается int flight_id в вашем классе dto.Измените тип flight_id на Integer и добавьте еще одну ссылку на Flight в классе TickerDTO.Попробуйте ниже преобразовать его в объект Flight:

public class TicketDto {
private int ticket_id;

private int place;

private String name;

private String surname;

private Flight flight;

private Customer customer_id;

@JsonProperty("flight_id")
private void unpackNested(Integer flight_id) {
    this.flight = new Flight();
    flight.setFlight_id(flight_id);
}

Или, если вы не хотите менять класс ticketDto, измените свой json на:

{
"name": "name",
"surname": "surname",
"flight_id": {
  "flight_id" : 123
}
}
0 голосов
/ 17 декабря 2018

Вам нужно создать конструктор в Flight с помощью @ JsonCreator :

@JsonCreator
public Flight (@JsonProperty("flight_id") Integer flight_id ) {
    this.flight_id = flight_id;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...