【问题标题】:GSON Expected BEGIN_ARRAY but was STRINGGSON 应为 BEGIN_ARRAY,但为 STRING
【发布时间】:2015-11-30 03:14:30
【问题描述】:

我正在尝试将一个 gson 字符串解析为我的 java 类,但由于照片的原因,我不断收到异常。

我正在使用 MySQL,图像有一个 Blob 列。

我在Android和服务器中的java类是这样的

public class Cliente {

    private Integer id;
    private byte[] foto;
    private String nome;
    private Date data_nascimento;
    private String endereco;
    private String telefone;
    private boolean ativo;
    private Date data_cadastro;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public byte[] getFoto() {
        return foto;
    }

    public void setFoto(byte[] foto) {
        this.foto = foto;
    }

    public String getNome() {
        return nome;
    }

    public void setNome(String nome) {
        this.nome = nome;
    }

    public Date getData_nascimento() {
        return data_nascimento;
    }

    public void setData_nascimento(Date data_nascimento) {
        this.data_nascimento = data_nascimento;
    }

    public String getEndereco() {
        return endereco;
    }

    public void setEndereco(String endereco) {
        this.endereco = endereco;
    }

    public String getTelefone() {
        return telefone;
    }

    public void setTelefone(String telefone) {
        this.telefone = telefone;
    }

    public boolean isAtivo() {
        return ativo;
    }

    public void setAtivo(boolean ativo) {
        this.ativo = ativo;
    }

    public Date getData_cadastro() {
        return data_cadastro;
    }

    public void setData_cadastro(Date data_cadastro) {
        this.data_cadastro = data_cadastro;
    }


}

JSON 字符串列表(foto 字段为 NULL,因为字符有限)

[{"id":1,"foto":null,"nome":"Guilherme","data_nascimento":"1993-12-23","endereco":"Rua Jornalista Angelo Zanuzzi, 560","telefone":"37055056","ativo":true,"data_cadastro":"2015-08-26"},{"id":2,"foto":null,"nome":"Lucas","data_nascimento":"2015-09-02","endereco":"Rua Jornalista Angelo Zanuzzi, 560","telefone":"37055056","ativo":true,"data_cadastro":"2015-08-26"}]

解析

ResponseEntity<?> responseEntity = Rest.makeRequest("services/clientes", HttpMethod.GET, null);
clienteList = gson.fromJson(responseEntity.getBody().toString(), new TypeToken<List<Cliente>>() {

在 foto 字段上使用 NULL,gson 效果很好,但是当图像来自我的数据库时,它会引发以下异常

com.google.gson.JsonSyntaxException: java.lang.IllegalStateException: Expected BEGIN_ARRAY but was STRING at line 1 column 18 path $[0].foto

我不知道如何将我的字符串解析为字节数组!

编辑

我的 JSON 是正确的,当我复制/粘贴时忘记输入 []。

这是带有来自mysql/hibernate的图像(blob)的Json的开始

由于篇幅太长,我无法发布整个代码

[{"id":1,"foto":"/9j/4AAQSkZJRgABAgAAAQABAAD/7QA2UGhvdG9zaG9wIDMuMAA4QklNBAQAAAAAABkcAmcAFEphUnk5alpFY3RFUWo5Zy1adUxSAP/iC/hJQ0NfUFJPRklMRQABAQAAC+gAAAAAAgAAA

然后,当 GSON 尝试转换时,我得到了错误。

com.google.gson.JsonSyntaxException: java.lang.IllegalStateException: Expected BEGIN_ARRAY but was STRING at line 1 column 18 path $[0].foto

问题是,HIBERNATE 将照片作为 STRING 而不是 BYTE[] Array 发送

然后,当我尝试解析时,GSON 抛出异常。 如果我将我的 Android 模型照片更改为字符串(私有字符串照片),gson 会正确解析,但我无法弄清楚如何将这个“字节字符串”放入 imageview。

我想接收 byte[] 以将其设置为图像视图

【问题讨论】:

  • 请贴一些你的相关代码,也可能是json字符串
  • Json 字符串太大,无法发布(因为图片有 7342 个字符),我会用代码更新。
  • 我遇到了同样的问题,结果发现服务器响应以字符串形式出现,而其他一些则以数组形式出现
  • JSON 结构是否正确?如果是,则不是有效的 json
  • 为什么你没有 JsonArray?像这样 [ {"id":1,...,...},{"id":2,....."} ] 或者那是你真正的 json。你有 {"id":1,. ..,...},{"id":2,....."} 还是您刚刚在评论中遗漏了?

标签: java android mysql json gson


【解决方案1】:

解决方案

实际上,Hibernate 将照片数据作为字符串发送回,所以我必须将我在 android 中的模型更改为

private String foto;

而不是

private byte[] foto;

而且,在把它变成我的 ImageView 之前,我必须用

解码字符串
byte[] bytes = Base64.decode(itemCardCliente.getFoto(), Base64.DEFAULT);
Bitmap bitmap = BitmapFactory.decodeByteArray(bytes, 0, bytes.length);
imageView.setImageBitmap(bitmap);

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-03-10
    • 2013-05-15
    • 2015-01-24
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多