Ir ao conteúdo
  • Cadastre-se

Conversão de ArrayList com Gson


Posts recomendados

Olá, estou desenvolvendo um web-service e tive alguns problemas na hora de usar a biblioteca Gson, o que acontece é o seguinte, eu uso a biblioteca Gson para converter um ArrayList que contém vários objetos do tipo Contato para Json, porém quando eu faço a conversão, na saída só aparece " [] ", já coloquei dois objetos do tipo Contato manualmente para ter certeza que o problema não estava na obtenção das informações no banco de dados, e aconteceu a mesma coisa. O que eu faço para o Gson fazer a conversão corretamente?

 

Classe Contato:

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */

package modelo;

/**
 *
 *
 */
public class Contato {
    
    private int id;
    private String nome;
    private String cel;
    private String tel;
    private String email;

    public int getId() {
        return id;
    }

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

    public String getNome() {
        return nome;
    }

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

    public String getCel() {
        return cel;
    }

    public void setCel(String cel) {
        this.cel = cel;
    }

    public String getTel() {
        return tel;
    }

    public void setTel(String tel) {
        this.tel = tel;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

 

Função que devolve o ArrayList:

public ArrayList<Contato> buscar(Contato contato)
    {
        String query = "SELECT * FROM Contatos where ";
        ArrayList<Contato> retorno = new ArrayList<>();
        
        String nm = contato.getNome();
        String cel = contato.getCel();
        String tel = contato.getTel();
        String email = contato.getEmail();
        
        try {
  			//Montagem da Query
            if("null".equals(email) && "null".equals(tel) && "null".equals(cel) && "null".equals(nm)){
                query = "Select * from Contatos";
            } else {
                if (!nm.equals("null")) {
                    query += "nome = " + nm;
                }

                if (!cel.equals("null") && !nm.equals("null")) {
                    query += " and cel = " + cel;
                } else if (!cel.equals("null")) {
                    query += "cel = " + cel;
                }

                if ((!tel.equals("null") && !cel.equals("null")) || (!tel.equals("null") && !nm.equals("null"))){
                    query += " and tel = " + tel;
                } else if (!tel.equals("null")) {
                    query += "tel = " + tel;
                }

                if ((!email.equals("null") && !tel.equals("null")) || (!email.equals("null") && !cel.equals("null")) || (!email.equals("null") && !nm.equals("null"))) {
                    query += " and email = " + email;
                } else if (!email.equals("null")) {
                    query += "email = " + email;
                }
            }
  			
  			//Obtenção dos dados
            PreparedStatement pst = Conexao.getPreparedStatement(query);
            ResultSet res = pst.executeQuery();
            while(res.next())
            {
                Contato lContato = new Contato();
              	lContato.setId(res.getInt("id"));  
              	lContato.setNome(res.getString("nome"));
                lContato.setCel(res.getString("cel"));
                lContato.setTel(res.getString("tel"));
                lContato.setEmail(res.getString("email"));
                
                retorno.add(lContato);
            }
            
        } catch (SQLException ex) {
            Logger.getLogger(ContatoDAO.class.getName()).log(Level.SEVERE, null, ex);        
        }
        
        return retorno;
    }

 

Função que retorna o Json:

@GET
    @Produces("application/json")
    @Path("Contato/get/buscar/{nm}/{cel}/{tel}/{email}")
    public String buscar(@PathParam("nm") String nm, @PathParam("cel") String cel, @PathParam("tel") String tel, @PathParam("email") String email){
        
        ArrayList<Contato> lista;
        ContatoDAO dao = new ContatoDAO();
        Contato contato = new Contato();
        
        contato.setNome(nm);
        contato.setCel(cel);
        contato.setTel(tel);
        contato.setEmail(email);
        
        lista = dao.buscar(contato); //Essa é a função citada anteriormente
        Gson g = new Gson();
        return g.toJson(lista);
    }

 

Link para o comentário
Compartilhar em outros sites

Não fiz os testes, mas tente três coisas:

 

- Crie o Gson com builder: Gson g = new GsonBuilder().create(); // não sei se vai mudar algo

 

- Crie um objeto para encapsular a lista:

public static class Encapsulador {
	public List<Contato> contatos;
}

Defina o campo "contatos" e use o Gson sobre o objeto Encapsulador. Se der certo, então pode ser que o Gson não funcione corretamente direto em uma lista.

 

- Converta a lista em array e passe ao Gson... gson.toJson(lista.toArray(new Contato[lista.size]));

 

 

E claro, assumi que os objetos estão na lista! Pode fazer alguma saída de log ou debug para verificar se estão na lista no momento da conversão.

Link para o comentário
Compartilhar em outros sites

  • 5 semanas depois...
Visitante
Este tópico está impedido de receber novas respostas.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...