Hace algún tiempo vimos cómo decodificar o parsear el formato JSON en Java, pero no vimos cómo convertir un objeto de Java a una cadena de JSON.
Lo que vamos a hacer en este post es mostrar cómo codificar o convertir un objeto que definamos en Java a su representación JSON.
Esto va a funcionar para todos los tipos de datos y clases dentro de clases, siempre y cuando definamos los getters de las cosas que queremos que se expongan.
Agrega la librería de org.json, luego define los getters en la clase que quieres codificar. En el código donde quieras convertir a JSON crea un nuevo objeto de tipo JSONObject y pásale la instancia de la clase a codificar en el constructor.
Luego llama al método toString
del objeto que acabas de crear y ya está, tendrás la representación.
Si algo no te quedó claro, sigue leyendo.
Recuerda ver el tutorial anterior para que instales la librería de org.json. También recomiendo que instales NetBeans para que puedas agregar la librería JAR fácilmente.
No voy a explicar la ventaja o razón de usar getters en Java. Simplemente daré un pequeño repaso.
Una clase tiene propiedades o variables dentro de ella. Por ejemplo, la clase Mascota
tiene la propiedad nombre
de tipo String
. Al declarar la variable la ponemos como privada:
private String nombre;
De esta manera no se puede acceder a ella usando:
String nombre = instanciaDeMascota.nombre;
Sino que debemos definir un método llamado getter en donde devolvemos el nombre:
public String getNombre{return nombre;}
Y al querer acceder a la propiedad usamos:
String nombre = instanciaDeMascota.getNombre();
Esto debemos hacer con todas las propiedades que queramos que sean codificadas con JSON.
Ahora que ya entendimos esa parte vamos a hacer un pequeño ejercicio. Lo que haremos será definir dos clases, una que va dentro de otra y al final codificar a esta última. Será una clase de tipo Mascota
y otra de tipo Raz
a.
La raza tiene Nombre y País. Tal vez en la vida real no es así pero no importa, es un ejemplo. Esta clase es una propiedad de Mascota. Veamos el código de Raza:
public class Raza {
private String nombre, pais;
public Raza(String nombre, String pais) {
this.nombre = nombre;
this.pais = pais;
}
public String getNombre() {
return nombre;
}
public void setNombre(String nombre) {
this.nombre = nombre;
}
public String getPais() {
return pais;
}
public void setPais(String pais) {
this.pais = pais;
}
}
Y el de Mascota, que a su vez usa a Raza:
public class Mascota {
private String nombre;
private int edad;
private String[] amigos;
private Raza raza;
public Mascota(String nombre, int edad, String[] amigos, Raza raza) {
this.nombre = nombre;
this.edad = edad;
this.amigos = amigos;
this.raza = raza;
}
public Raza getRaza() {
return raza;
}
public void setRaza(Raza raza) {
this.raza = raza;
}
public String getNombre() {
return nombre;
}
public void setNombre(String nombre) {
this.nombre = nombre;
}
public int getEdad() {
return edad;
}
public void setEdad(int edad) {
this.edad = edad;
}
public String[] getAmigos() {
return amigos;
}
public void setAmigos(String[] amigos) {
this.amigos = amigos;
}
}
Vemos que tiene un arreglo de tipo String junto con otras propiedades. Recuerda que todo esto es para demostrar cómo es que la codificación JSON llega a esa profundidad y lee todos los datos.
Para codificar a JSON primero debemos tener una instancia de una clase. Es decir, crear un objeto a partir de una clase. Así:
public class CodificarJSON {
public static void main(String[] args) {
String[] amigos = {"Guayaba", "Snowball", "Cuco"};
Raza raza = new Raza("Caniche", "Francia");
Mascota mascota = new Mascota("Maggie", 3, amigos, raza);
}
}
Estamos creando un objeto de la clase Mascota. Antes de crearla definimos la lista de amigos y la raza para que el código sea más legible.
Vuelvo a recordar que todas las propiedades que queremos que sean codificadas deben ser expuestas a través de los getters.
Ahora sí a lo que venimos. Importamos lo que vamos a usar:
import org.json.JSONObject;
Es lo único que necesitamos. La magia radica en crear un objeto de tipo JSONObject pasando la instancia del objeto a codificar en el constructor y luego llamar a su método toString
; eso automáticamente regresará el JSON como String
.
JSONObject jsonObject = new JSONObject(mascota);
String codificado = jsonObject.toString();
System.out.println("Codificado: " + codificado);
No es magia, simplemente el método lee todos los getters y los pone en un JSON. Si no encuentra getters, no pondrá los datos. En fin, la salida es la siguiente:
La ventaja de esto es que si agregamos más propiedades simplemente hay que agregar los getters y todo seguirá funcionando de maravilla.
El código completo del método main queda así:
public static void main(String[] args) {
String[] amigos = {"Guayaba", "Snowball", "Cuco"};
Raza raza = new Raza("Caniche", "Francia");
Mascota mascota = new Mascota("Maggie", 3, amigos, raza);
JSONObject jsonObject = new JSONObject(mascota);
String codificado = jsonObject.toString();
System.out.println("Codificado: " + codificado);
}
Con JSONObject es fácil codificar un objeto de cualquier tipo a su representación como JSON. Después esa cadena puede ser enviada a un servidor.
Te invito a ver más sobre Java aquí.
El día de hoy te mostraré cómo crear un servidor HTTP (servidor web) en Android…
En este post te voy a enseñar a designar una carpeta para imprimir todos los…
En este artículo te voy a enseñar la guía para imprimir en una impresora térmica…
Hoy te voy a mostrar un ejemplo de programación para agregar un módulo de tasa…
Los usuarios del plugin para impresoras térmicas pueden contratar licencias, y en ocasiones me han…
Hoy voy a enseñarte cómo imprimir el € en una impresora térmica. Vamos a ver…
Esta web usa cookies.