Json
Json
Json
JSON, acrónimo de JavaScript Object Notation, es un formato de texto ligero para el intercambio de datos. JSON es un subconjunto de la notación
literal de objetos de JavaScript aunque hoy, debido a su amplia adopción como alternativa a XML, se considera un formato de lenguaje independiente.
Una de las supuestas ventajas de JSON sobre XML como formato de intercambio de datos es que es mucho más sencillo escribir un analizador
sintáctico (parser) de JSON. En JavaScript, un texto JSON se puede analizar fácilmente usando la función eval(), lo cual ha sido fundamental para
que JSON haya sido aceptado por parte de la comunidad de desarrolladores AJAX, debido a la ubicuidad de JavaScript en casi cualquier navegador
web.
En la práctica, los argumentos a favor de la facilidad de desarrollo de analizadores o de sus rendimientos son poco relevantes, debido a las cuestiones
de seguridad que plantea el uso de eval() y el auge del procesamiento nativo de XML incorporado en los navegadores modernos. Por esa razón,
JSON se emplea habitualmente en entornos donde el tamaño del flujo de datos entre cliente y servidor es de vital importancia (de aquí su uso por
Yahoo, Google, etc, que atienden a millones de usuarios) cuando la fuente de datos es explícitamente de fiar y donde no es importante el no disponer
de procesamiento XSLT para manipular los datos en el cliente.
Si bien es frecuente ver JSON posicionado contra XML, también es frecuente el uso de JSON y XML en la misma aplicación. Por ejemplo, una
aplicación de cliente que integra datos de Google Maps con datos meteorológicos en SOAP hacen necesario soportar ambos formatos.
En diciembre de 2005 Yahoo! comenzó a dar soporte opcional de JSON en algunos de sus servicios web.1
Ni Yahoo, ni Google emplean JSON, sino LJS[cita requerida]. Una de las cualidades intrínsecas de Javascript denominada LJS (Literal Javascript)
facilita el flujo de datos e incluso de funciones, para la cual no requiere la función eval() si son datos los que se transfieren como en el caso de
XML. Todo lo referente a transferencia de datos en todos sus tipos, incluyendo arrays, booleans, integers, etc. no requieren de la función eval() y
es precisamente en eso en donde supera por mucho JavaScript al XML, si se utiliza el LJS y no la incorrecta definición de JSON.
Sintaxis
Los tipos de datos disponibles con JSON son:
• Números: Se permiten números negativos y opcionalmente pueden contener parte fraccional separada por puntos. Ejemplo: 123.456
• Cadenas: Representan secuencias de cero o más caracteres. Se ponen entre doble comilla y se permiten cadenas de escape. Ejemplo:
"Hola"
• Booleanos: Representan valores booleanos y pueden tener dos valores: true y false
• null: Representan el valor nulo.
• Array: Representa una lista ordenada de cero o más valores los cuales pueden ser de cualquier tipo. Los valores se separan por comas y el
vector se mete entre corchetes. Ejemplo ["juan","pedro","jacinto"]
• Objetos: Son colecciones no ordenadas de pares de la forma <nombre>:<valor> separados por comas y puestas entre llaves. El nombre
tiene que ser una cadena y entre ellas. El valor puede ser de cualquier tipo. Ejemplo:
{"departamento":8,"nombredepto":"Ventas","director": "juan rodriguez","empleados":
[{"nombre":"Pedro","apellido":"Fernandez"},{"nombre":"Jacinto","apellido":"Benavente"} ]}
Modelos de procesamiento
Al ser JSON un formato muy extendido para el intercambio de datos, se han desarrollado API para distintos lenguajes (por ejemplo ActionScript, C,
C++, C#, ColdFusion, Common Lisp, Delphi, E, Eiffel, Java, JavaScript, ML, Objective-C, Objective CAML, Perl, PHP, Python, Rebol, Ruby, Lua y
Visual FoxPro) que permiten analizar sintácticamente, generar, transformar y procesar este tipo de datos.
Los modelos de programación más utilizados para tratar con JSON en los distintos lenguajes son:2
• Modelo de objeto.- El JSON completo es almacenado en memoria en un formato de árbol. Este árbol es navegado, analizado y modificado
con las API apropiadas. Como lo carga todo en memoria y luego lo procesa este modelo consume muchos recursos. Sin embargo es muy
flexible para manipular el contenido. Este modelo es permitido por ejemplo en java por la JSR 353 y por la biblioteca Jackson
• Modelo de flujo: Los datos son leídos o escritos en bloques. Por ejemplo cada vez que se lee un bloque el analizador genera eventos
apropiados para indicar el tipo de bloque de que se trata. El cliente puede procesar el contenido escuchando los eventos apropiados.
Además es el cliente el que decide como se va leyendo el JSON permitiendo parar o saltar contenidos en mitad del proceso. El proceso de
escritura tiene propiedades análogas. Por ejemplo este modelo es permitido en java por la JSR 353.
• Convirtiendo los objetos JSON en objetos del lenguaje. En java esto es realizado por ejemplo por las bibliotecas Jackson y Gson.
Uso de JSON
En teoría, es trivial analizar JSON en JavaScript usando la función JSON.parse() incorporada en el lenguaje. Por ejemplo:
miObjeto = JSON.parse(json_datos);
En la práctica, las consideraciones de seguridad por lo general recomiendan no usar eval sobre datos crudos y debería usarse un analizador JavaScript
distinto para garantizar la seguridad. El analizador proporcionado por JSON.org usa eval() en su función de análisis, protegiéndola con una
expresión regular de forma que la función sólo ve expresiones seguras.
function handle_json() {
if (http_request.readyState == 4) {
if (http_request.status == 200) {
var json_data = http_request.responseText;
var the_object = eval("(" + json_data + ")");
} else {
alert("Ocurrio un problema con la URL.");
}
http_request = null;
}
}
Obsérvese que el uso de XMLHttpRequest en este ejemplo no es compatible con todos los navegadores, ya que existen variaciones sintácticas para
Internet Explorer, Opera, Safari, y navegadores basados en Mozilla.
También es posible usar elementos <iframe> ocultos para solicitar los datos de manera asíncrona, o usar peticiones <form
target="url_to_cgi_script" />. Estos métodos eran los más habituales antes del advenimiento del uso generalizado de XMLHttpRequest.
Hay una biblioteca3 para el framework .NET que exporta clases .NET con la sintaxis de JSON para la comunicación entre cliente y servidor, en
ambos sentidos.
Ejemplo de JSON
A continuación se muestra un ejemplo simple de definición de barra de menús usando JSON y XML.
JSON:
{
"menu": {
"id": "file",
"value": "File",
"popup": {
"menuitem": [
{
"value": "New", "onclick": "CreateNewDoc()"
},{
"value": "Open", "onclick": "OpenDoc()"
},{
"value": "Close", "onclick": "CloseDoc()"
}
]
}
}
}
Los entornos en el servidor normalmente requieren que se incorpore una función u objeto analizador de JSON. Algunos programadores,
especialmente los familiarizados con el lenguaje C, encuentran JSON más natural que XML, pero otros desarrolladores encuentran su escueta
notación algo confusa, especialmente cuando se trata de datos fuertemente jerarquizados o anidados muy profundamente.
YAML es un superconjunto de JSON que trata de superar algunas de las limitaciones de éste. Aunque es significativamente más complejo,5 aún
puede considerarse como ligero. El lenguaje de programación Ruby utiliza YAML como el formato de serialización por defecto. Así pues, es posible
manejar JSON con bastante sencillez.
YAML
YAML es un formato de serialización de datos legible por humanos inspirado en lenguajes como XML, C, Python, Perl, así como el formato para
correos electrónicos especificado por el RFC 2822. YAML fue propuesto por Clark Evans en 2001, quien lo diseñó junto a Ingy döt Net y Oren Ben-
Kiki.
YAML es un acrónimo recursivo que significa "YAML Ain't Another Markup Language" (en castellano, "YAML no es otro lenguaje de marcado"). A
comienzos de su desarrollo, YAML significaba "Yet Another Markup Language" ("Otro lenguaje de marcado más") para distinguir su propósito
centrado en los datos en lugar del marcado de documentos. Sin embargo, dado que se usa frecuentemente XML para serializar datos y XML es un
auténtico lenguaje de marcado de documentos, es razonable considerar YAML como un lenguaje de marcado ligero.
Características
YAML fue creado bajo la creencia de que todos los datos pueden ser representados adecuadamente como combinaciones de listas, hashes (mapeos) y
datos escalares (valores simples). La sintaxis es relativamente sencilla y fue diseñada teniendo en cuenta que fuera muy legible pero que a la vez fuese
fácilmente mapeable a los tipos de datos más comunes en la mayoría de los lenguajes de alto nivel. Además, YAML utiliza una notación basada en el
indentación y/o un conjunto de caracteres Sigil distintos de los que se usan en XML, haciendo que sea fácil componer ambos lenguajes.
• Los contenidos en YAML se describen utilizando el conjunto de caracteres imprimibles de Unicode, bien en UTF-8 o UTF-16.
• La estructura del documento se denota indentando con espacios en blanco; sin embargo no se permite el uso de caracteres de tabulación
para indentar.
• Los miembros de las listas se denotan encabezados por un guion ( - ) con un miembro por cada línea, o bien entre corchetes ( [ ] ) y
separados por coma espacio ( , ).
• Los arrays asociativos se representan usando los dos puntos seguidos por un espacio. en la forma "clave: valor", bien uno por línea o entre
llaves ( { } ) y separados por coma seguida de espacio ( , ).
• Un valor de un array asociativo viene precedido por un signo de interrogación ( ? ), lo que permite que se construyan claves complejas sin
ambigüedad.
• Los valores sencillos (o escalares) por lo general aparecen sin entrecomillar, pero pueden incluirse entre comillas dobles ( " ), o comillas
simples ( ' ).
• En las comillas dobles, los caracteres especiales se pueden representar con secuencias de escape similares a las del lenguaje de
programación C, que comienzan con una barra invertida ( \ ).
• Se pueden incluir mútliples documentos dentro de un único flujo, separándolos por tres guiones ( --- ); los tres puntos ( ... ) indican el fin
de un documento dentro de un flujo.
• Los nodos repetidos se pueden denotar con un ampersand ( & ) y ser referidos posteriormente usando el asterisco ( * )
• Los comentarios vienen encabezados por la almohadilla ( # ) y continúan hasta el final de la línea.
• Los nodos pueden etiquetarse con un tipo o etiqueta utilizando el signo de exclamación( ! ) seguido de una cadena que puede ser expandida
en una URL.
• Los documentos YAML pueden ser precedidos por directivas compuestas por un signo de porcentaje ( % ) seguidos de un nombre y
parámetros delimitados por espacios.. Hay definidas dos directivas en YAML 1.1:
• La directiva %YAML se utiliza para identificar la versión de YAML en un documento dado.
• La directiva %TAG se utiliza como atajo para los prefijos de URIs. Estos atajos pueden ser usados en las etiquetas de tipos de
nodos.
YAML requiere que las comas y puntos y comas que se utilicen como separadores en las listas sean seguidos por un espacio, de forma que los valores
escalares que contengan signos de puntuación (como 5,280 o http://www.wikipedia.org) se puedan representar sin necesidad de utilizar comillas.
Hay dos caracteres adicionales que están reservados en YAML para su posible estandarización en un futuro: la arroba ( @ ) y el acento grave ( ` ).
Ejemplos
Listas
--- # Películas favoritas, formato de bloque
- BotijoAzul
- BotijoVerde
- Viridiana
- Psicosis
--- # Lista de la compra, formato en línea
[leche, pan, huevos]
[chorizo, morcilla, botijo, pollo]
Implementaciones
Existen implementaciones de YAML para los siguientes lenguajes:
• JavaScript
• Objective-C
• Perl
• PHP
• Python
• Ruby (utiliza YAML como el formato de serialización por defecto; YAML está incluido en la biblioteca estándar desde la versión 1.8)
• Java
• Haskell