我想解析一個gson字符串到我的java類,但由於照片我不斷收到異常。GSON預計BEGIN_ARRAY,但是STRING
我正在使用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字符串列表(具有在照片字段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的確很棒,但是當圖像來自我的DB時,它會拋出f如果不是例外
com.google.gson.JsonSyntaxException: java.lang.IllegalStateException: Expected BEGIN_ARRAY but was STRING at line 1 column 18 path $[0].foto
我想不出如何解析我的字符串到字節數組!
編輯
我的JSON是正確的,當我複製/粘貼我忘了[]。
這是將JSON與從MySQL圖像(BLOB)開始時/休眠
我不能發佈,因爲lenght的整個代碼
[{"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是發送照片作爲字符串而不是byte []數組
然後,當我嘗試解析,GSON throwns除外。 如果我更改我的Android模型foto到String(private String foto),gson解析正確,但我無法弄清楚如何將這個「字節串」放入imageview。
我想收到[]把它設置成一個imageview的
字符串請發表您的一些相關的代碼,並且可以是JSON字符串太 – Emil
JSON字符串過大後,因爲(7342個CARACTERES圖片),我會用代碼更新。 –
我有同樣的問題,事實證明,服務器的響應是作爲一個字符串和一個其他的數組作爲 –