Невозможно десериализовать экземпляр `java.util.ArrayList` - PullRequest
1 голос
/ 03 мая 2019

У меня проблемы с попыткой получить данные из файла JSON.Моя JAVA-сторона работала, но были внесены изменения в PHP, который собирает JSON, так как я не могу выполнить синтаксический анализатор, я не знаю в PHP, чтобы знать формат JSON, который я получаю, но у меня есть доступ к коду.Страница, которую монтирует JSON, выглядит так:

<?php
    $startTime = microtime(true);
    include_once("../utils/config.php");
    include_once("../utils/utils.php");
    include_once("../services/rest.utils.php");

    header("Content-Type: application/json",true);

    $from = getADate('from', true);
    $to = getADate('to', false);
    $fromDate = '';
    $toDate = '';
    if ($from <> '') { $fromDate = $from; }
    if ($to <> 'NULL') { $toDate = $to; }

    $body = file_get_contents('php://input');

    if (signatureCheck($body)) {
        $cta = 0;
        $database = conectaDatabase();
        $script = '';
        $pfx = Config::getPrefixo();

        $sql = "SELECT RelatorioID, ProfessorID, AlunoID, TurmaID,
                Bimestre, Data, TipoRelatorio, Conteudo, Situacao FROM {$pfx}Relatorios
                WHERE Data >= $fromDate";
        if ($toDate <> '') { 
            $sql .= " AND Data < $toDate";
        }   

        $qry = $database->query($sql);
        $lista = array();
        $cta = 0;
        while ($row = $qry->fetchObject()) {
            $row->TipoRelatorio = utf8_encode($row->TipoRelatorio);
            $row->Conteudo = utf8_encode($row->Conteudo);
            $lista[] = $row;
            $cta++;
        }

        @$output->response = new StdClass(); // Anonymous object, remove the warning
        $output->response->descricao = "$cta relatórios importados";
        $output->response->status = 200;
        $output->relatorios = $lista;

        $endTime = microtime(true);
        $timeSpent = $endTime - $startTime;
        $output->response->timeSpent = $timeSpent;

        $saida = json_encode($output, JSON_UNESCAPED_UNICODE);
        echo $saida;

        desconectaDB($database);
    } else {
        $description = "não autorizado";
        $status = "401";
        $endTime = microtime(true);
        $timeSpent = $endTime - $startTime;
        echo "{\"status\":{$status}, \"descricao\":\"$description\", \"timeSpent\": \"{$timeSpent}\"}"; 
    }

Это мой код Java, который получает данные из файла JSON.

public void myGeRelatorios() {

try {
    String targetUrl = "https://develop.bedelonline.com.br/services/importa.relatorios.php?from=2019-01-03T00:00:00Z";

    HttpHeaders header = new HttpHeaders();
    header = Useful.newGetHeaderForImport();
    HttpEntity<String> entity = new HttpEntity<>("parameters", header);
    ResponseEntity<List<RelatorioResponse>> response = rt.exchange(targetUrl, HttpMethod.GET, entity, new ParameterizedTypeReference<List<RelatorioResponse>>() {});
    List<RelatorioResponse> responses = response.getBody();
    doWithResponse(responses);
} catch (Exception e) {
    LOGGER.error(e.getMessage());
}

}

Мой класс ответа

public class RelatorioResponse {


    @JsonProperty("RelatorioID")
    private Integer RelatorioID;

    @JsonProperty("ProfessorID")
    private Integer ProfessorID;

    @JsonProperty("AlunoID")
    private Integer AlunoID;

    @JsonProperty("TurmaID")
    private Integer TurmaID;

    @JsonProperty("Bimestre")
    private Integer Bimestre;

    @JsonProperty("Data")
    private Date Data;

    @JsonProperty("TipoRelatorio")
    private String TipoRelatorio;

    @JsonProperty("Conteudo")
    private String Conteudo;

    @JsonProperty("Situacao")
    private Integer Situacao;

    public Integer getRelatorioID() {
        return RelatorioID;
    }

    public void setRelatorioID(Integer relatorioID) {
        RelatorioID = relatorioID;
    }

    public Integer getProfessorID() {
        return ProfessorID;
    }

    public void setProfessorID(Integer professorID) {
        ProfessorID = professorID;
    }

    public Integer getAlunoID() {
        return AlunoID;
    }

    public void setAlunoID(Integer alunoID) {
        AlunoID = alunoID;
    }

    public Integer getTurmaID() {
        return TurmaID;
    }

    public void setTurmaID(Integer turmaID) {
        TurmaID = turmaID;
    }

    public Integer getBimestre() {
        return Bimestre;
    }

    public void setBimestre(Integer bimestre) {
        Bimestre = bimestre;
    }

    public Date getData() {
        return Data;
    }

    public void setData(Date data) {
        Data = data;
    }

    public String getTipoRelatorio() {
        return TipoRelatorio;
    }

    public void setTipoRelatorio(String tipoRelatorio) {
        TipoRelatorio = tipoRelatorio;
    }

    public String getConteudo() {
        return Conteudo;
    }

    public void setConteudo(String conteudo) {
        Conteudo = conteudo;
    }

    public Integer getSituacao() {
        return Situacao;
    }

    public void setSituacao(Integer situacao) {
        Situacao = situacao;
    }
}

И эта ошибка возникает, когда я пытаюсь проанализировать JSON

org.springframework.web.client.RestClientException: Error while extracting response for type
 [java.util.List<com.test.bws.response.RelatorioResponse>] and 
content type [application/json]; nested exception is org.springframework.http.converter.HttpMessageNotReadableException: JSON parse error: Cannot deserialize instance of `java.util.ArrayList` out of START_OBJECT token; nested exception is com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `java.util.ArrayList` out of START_OBJECT token
 at [Source: (PushbackInputStream); line: 1, column: 1]


Error while extracting response for type [java.util.List<com.test.bws.response.RelatorioResponse>] and content type [application/json]

org.springframework.http.converter.HttpMessageNotReadableException: JSON parse error: Cannot deserialize instance of `java.util.ArrayList` out of START_OBJECT token; nested exception is com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of `java.util.ArrayList` out of START_OBJECT token
 at [Source: (PushbackInputStream); line: 1, column: 1]

JSON test

Спасибо за любую помощь

1 Ответ

1 голос
/ 03 мая 2019

Проблема в том, что ваш JSON выглядит следующим образом:

{
  "response": {
    ...
  },
  "relatorios": [
    {
      ...
    }
  ]
}

И вы пытаетесь сопоставить это непосредственно со списком relatorios.Вместо этого вы должны создать еще один RestResponse объект.Он должен содержать все содержимое ответа JSON:

public class RestResponse {
    private MyResponse response;
    private List<RelatorioResponse> relatorios;
    // getter and setter
}

Объект response должен представлять часть response в вашем JSON.Если вам это не нужно, вы также можете добавить @JsonIgnoreProperties(ignoreUnknown = true) в свой класс RestResponse и пропустить атрибут response:

@JsonIgnoreProperties(ignoreUnknown = true)
public static class RestResponse {
    private List<RelatorioResponse> relatorios;
    // getter and setter
}

Тогда ваш код запроса должен выглядеть следующим образом:

HttpEntity<String> entity = new HttpEntity<>("parameters", new HttpHeaders());
ResponseEntity<RestResponse> response = new RestTemplate().exchange(targetUrl, HttpMethod.GET, entity, RestResponse.class);
List<RelatorioResponse> responses = response.getBody().getRelatorios();
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...