Pular para o conteúdo principal

JSON fácil em Java com GSon !

Ola pessoal !

O formato JSON (JavaScript Object Notation) vem se consagrando cada vez mais na comunicação de dados, principalmente nos dispositivos móveis devido a esse formato ser mais leve que o XML e também mais legível.
Uma prova disso são as inúmeras bibliotecas que existem para manipular esse formato, e no caso do Android, o suporte ao JSON é nativo. Mas apesar de ter esse suporte nativo, algumas operações devem ser feitas manualmente e o código acaba ficando um pouco verboso e repetitivo, já que para cada objeto que se deseja transmitir é necessário fazer um método que lê as propriedades do JSON e faz as devidas atribuições no seu objeto Java.

Vamos supor o seguinte objeto sendo transmitido em JSON:

{
  user: {
    id: 123456,
    name: "Neto Marin",
    username: "netomarin",
    email: "netomarin@globalcode.com.br"
  }
}

Se você fosse tratar um Webservice que envia esse JSON para o seu aplicativo Android, além de criar a o Java Bean desse objeto, a classe User por exemplo, você também precisaria programar  um método em algum controller  (ou em uma classe qualquer) para carregar o bean com os dados que vieram pelo JSON, por exemplo:

public User loadUserFromJSON(String jsonString) {
    User user = new User();
    try {
        JSONObject userObject = new JSONObject(jsonString);
        user.setId(userObject.getInt("id"));
        user.setName(userObject.getString("name"));
        user.setUsername(userObject.getString("username"));
        user.setEmail(userObject.getString("email"));
    } catch (JSONException e) {
        e.printStackTrace();
    }
    
    return user;
}

E assim teria que fazer para cada objeto que você quisesse receber via JSON. Sem falar nas atualizações que teria que fazer em caso de mudança do objeto ou problemas que poderia ter com erros ou trocas nos nomes das propriedades.
Além do parser para carregar uma instância de User a partir de um JSON, caso você precise enviar o mesmo JSON para o servidor, teria que ter um método para converter o seu bean em uma String no formato, e então, teria um método parecido com isso:

public String userToJSON(User user) {
    JSONObject object = new JSONObject();
    try {
        object.put("id", user.getId());
        object.put("name", user.getName());
        object.put("username", user.getUsername());
        object.put("email", user.getEmail());
    } catch (JSONException e) {
        e.printStackTrace();
    }
    
    return object.toString();
}

Apresentando, Gson !

Então, pra dar uma ajuda nessa tarefa toda, o pessoal do Google criou o projeto Gson, que tem como principais objetivos:
  • Prover uma interface simples para ler e exportar no formato JSON.
  • Permitir que objetos pré-existentes e que não possam ser alterados sejam convertidos para e partir de JSON.
  • Suporte ao generics do Java.
  • Representação customizada de objetos.
  • Suporte a tipos complexos de objetos.
Dessa forma, a promessa do Gson é que com apenas poucas linhas você consiga gerar objetos a partir de uma String JSON. A conversão do objeto user que foi demonstrado acima, se for utilizar Gson, ficaria assim:

public User loadUserFromJSONGson(String jsonString) {
    Gson gson = new Gson();
    User user = gson.fromJson(jsonString, User.class);
    return user;
}

Bem mais fácil não? E na hora de enviar essa classe User para o servidor, seria tão simples assim? Vejamos:

//criação do objeto para demonstrar...
User user = new User();
user.setId(123);
user.setName("João da Silva");
user.setEmail("joaodasilva@mail.com");
user.setUsername("joaosilva");
    
//código que faz o trabalho ;-)
Gson gson = new Gson();
String userJSONString = gson.toJson(user);

//Para ver o resultado no Logcat    
Log.d("Gson", "user JSON String: "+userJSONString);

Mas é só isso ?!?!

Claro que não ! O próprio formato JSON tem uma série de particularidades e também limites. E a biblioteca Gson está em desenvolvimento, e é claro, também tem as suas limitações. Por isso, visite o site do projeto e também o Gson User Guide que conta com diversos exemplos mais avançados, envolvendo objetos complexos, arrays e generics!

Esse exemplo que apresentei serve para mostrar a simplicidade da idéia, e que será o suficiente caso você apenas receba e envie objetos simples. Boa sorte! ;-)

Da pra usar com projetos Android?

Sim, basta fazer o download do zip da biblioteca, descompactar e copiar o JAR para a pasta libs do seu projeto Android (caso não tenha a pasta, basta criar...). Depois, no Eclipse, clique com o botão direito em cima do JAR e selecione a opção Build Path --> Add to Build Pah e pronto, você já pode usar normalmente no seu projeto!

Abraços
Neto Marin

Comentários

Daniel disse…
Componente sagaz o Gson. Utilizamos em projetos, muito eficiente.
Rafael Spessotto disse…
Ola!

eu sei que esse post e antigo, mas comecei a seguir os seu tutorial de android, so que cada vez que eu dou "run as android application" ele roda o emulador mas a aplicacao nao aparece no emulador...ela esta instalada mas ela nao roda automaticamente... tem alguma ideia?

abracos
Unknown disse…
Uia!

Simples e objetivo! Parabéns pelo post.
Unknown disse…
Muito bom, parabéns.
Unknown disse…
Alguém poderia indicar uma fonte onde encontro a utilização do GSon para utilização com RESTFul?

Postagens mais visitadas deste blog

Melhorando Performance de JPA com Spring Web Flow

No TDC2009 realizado pela Globalcode em São Paulo foi apresentado um Lightning Talk sobre um problema específico de performance em aplicações Web com JPA e uma possível solução usando o Spring Web Flow . Num período de 15 minutos, os slides a seguir foram apresentados e seguidos de alguns vídeos de demonstração de uma aplicação Web em execução. Melhorando performance do JPA com Spring Web Flow View more presentations from Dr. Spock . Nesta apresentação foi dito que temos encontrado problemas de performance em aplicações Web que utilizam as tecnologias JSF + JPA + Ajax quando precisamos gerenciar um contexto de persistência (EntityManager). Estes problemas se manifestam quando aplicamos uma resposta errada para a pergunta: Como gerenciar o contexto de persistência numa aplicação Web? Se as aplicações não usam Ajax e limitam-se ao modelo orientado a requisições, a solução mais comum é o uso do design pattern chamado "Open Session In View Filter". Através deste design

10 reasons why we love JSF

1. One-slide technology: it's so simple that I can explain basic JSF with one slide. 2. Easy to extend: components, listeners, render kit, Events, Controller, etc. 3. Real-world adoption: JBoss, Exadel, Oracle, IBM, ... 4. Architecture model: you can choose between more than 100 different architecture. 5. Open-mind community: using JSF you are going to meet very interesting people. 6. We are using JSF the last 5 years and we found very good market for JSF in Brazil 7. Progress: look to JSf 1.1 to JSF 1.2, JSF 1.2 to JSF 2.0. People are working really hard! 8. Many professionals now available 9. It's a standard. It's JCP. Before complain, report and help! 10. Ed Burns, spec leader, is an old Globalcode community friend! EXTRA: My wife is specialist in JSF. She's my F1 for JSF :) Nice job JSF community! -Vinicius Senger

O que é Lógica de programação?

Este é o segundo de uma série de posts voltados aos leitores do blog que estão dando início à carreira de desenvolvimento de software. O assunto de hoje é a lógica de programação. Para ler antes: Entendendo como funciona a programação de computadores: linguagens de programação, lógica, banco de dados A lógica de programação é um pré-requisito para quem quer se tornar um desenvolvedor de software, independente da linguagem de programação que se pretende utilizar. Mas o que é de fato a Lógica de Programação e como saber se eu tenho esse pré-requisito? A lógica de programação nada mais é do que a organização coerente das instruções do programa para que seu objetivo seja alcançado. Para criar essa organização, instruções simples do programa, como mudar o valor de uma variável ou desenhar uma imagem na tela do computador, são interconectadas a estruturas lógicas que guiam o fluxo da execução do programa. Isso é muito próximo ao que usamos em nosso cotidiano para realizar atividad

Dica rápida: Apagando registros duplicados no MySQL

Ola pessoal, Sei que vocês estão acostumados a ver posts meus sobre tecnologia móvel ou algo relacionado, mas hoje vou falar sobre um pequeno "truque" que usei esse final de semana com o MySQL. Eu estava desenvolvendo o lado servidor de uma nova aplicação mobile (ahh, então "tem a ver" com mobile hehe), e quando fui fazer alguns testes percebi que tinha quase 7 mil registros duplicados (!!!) na minha base de dados! Bom, o meu primeiro reflexo como programador foi pensar em fazer um "programinha" Java para buscar e deletar todos esses registros duplicados. Mas ai, resolvi tirar as teias de aranha dos neurônios e usar os vários anos de experiência que passei com SQL e criar uma query que fizesse esse trabalho todo de uma vez!! E a query ficou assim: delete from TABLE_NAME USING  TABLE_NAME, TABLE_NAME  AS  auxtable WHERE   ( NOT  TABLE_NAME.id  =  auxtable.id ) AND   ( TABLE_NAME.name  =  auxtable.name ) Explicação direta: TABLE_NAME

JavaMail: Enviando mensagem HTML com anexos

Introdução Depois do post "JavaMail: Enviando e-mail com Java" , que apresentava como enviar um e-mail com Java, resolvi complementar a assunto apresentando como enviar uma mensagem formatada, em HTML , e também como realizar o envio de anexos. Bibliotecas Além da biblioteca JavaMail, veja mais no post anterior , é necessário incluir o JavaBeans Activation Framework (JAF), apenas se a versão utilizada for anterior ao JSE 6.0 , que já tem o JAF incluso. O JAF está disponível em http://www.oracle.com/technetwork/java/javase/downloads/index-135046.html , e neste download encontramos, alguns exemplos na pasta demo , documentação, incluindo javadocs, na pasta docs e a biblioteca activation.jar , que deve ser acrescentada no classpath da aplicação para versões anteriores ao JSE 6.0. Exemplo Primeiramente devemos realizar a configuração da javax.mail.Session e da javax.mail.internet.MimeMessage , estes passos podem ser vistos no post anterior . Agora vamos montar um

TDC ONLINE: SUA PLATAFORMA DE PALESTRAS GRAVADAS DO TDC DISPONÍVEL

Além do conteúdo ao vivo transmitido online nas edições do TDC, agora você pode ter acesso à centenas de palestras gravadas, através da nossa nova plataforma de vídeos - o TDC Online, que reúne todas as Trilhas premium, Stadium e Salas dos Patrocinadores das edições anteriores de 2022, TDC Innovation e TDC Connections.  Para acessar, basta clicar na edição em que você participou ( TDC Innovation ou TDC Connections ); Fazer o mesmo login (com e-mail e senha) cadastrados na hora de adquirir ou resgatar o seu ingresso no TDC; E clicar na Trilha de sua opção, e de acordo com a modalidade do seu ingresso. Logo em seguida, você será direcionado para a seguinte página com a lista de todas as palestras por Trilha: Pronto! Agora você tem acesso à centenas de palestras gravadas da sua área de interesse, para assistir como e quando quiser! Caso tenha esquecido a senha, clique na opção "Esqueci a senha" , insira o e-mail que você realizou para o cadastro no evento, e aparecerá a op