JSON

JSON
https://json.org/, https://json.org/json-fr.html y https://json.org/json-it.html
Información general
Extensión de archivo .json
Tipo de MIME application/json
Tipo de formato Lenguaje de marcado
Extendido de JavaScript
Estándar(es)
Formato abierto Sí 
Crockford fue el primero en especificar y popularizar el JSON

JSON (acrónimo de JavaScript Object Notation, 'notación de objeto de JavaScript') es un formato de texto sencillo para el intercambio de datos. Se trata de un subconjunto de la notación literal de objetos de JavaScript, aunque, debido a su amplia adopción como alternativa a XML, se considera un formato independiente del lenguaje.

Una de las supuestas ventajas de JSON sobre XML como formato de intercambio de datos es que resulta mucho más sencillo escribir un analizador sintáctico (parser) para él.[1]​ En JavaScript, un texto JSON se puede analizar fácilmente usando la función eval(), algo que (debido a la ubicuidad de JavaScript en casi cualquier navegador web) ha sido fundamental para que haya sido aceptado por parte de la comunidad de desarrolladores AJAX.[2][3][4]

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.[5]​ 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, Mozilla, etc, que atienden a millones de usuarios, cuando la fuente de datos es explícitamente de fiar y donde no es importante el hecho de no disponer de procesamiento XSLT para manipular los datos en el cliente.

Si bien se tiende a considerar JSON como una alternativa a XML, lo cierto es que no es infrecuente el uso de JSON y XML en la misma aplicación; así, una aplicación de cliente que integra datos de Google Maps con datos meteorológicos en SOAP (Simple Object Access Protocol) necesita hacer uso de ambos formatos.

En diciembre de 2005, Yahoo! comenzó a dar soporte opcional de JSON en algunos de sus servicios web.[6]

Nombre y pronunciación

[editar]

En inglés, JSON se pronuncia de forma acronímica, como el nombre de la letra J (jay, /dʒeɪ/) seguido de la sílaba «son». El resultado habitual, con la primera sílaba tónica (/ˈdʒeɪsən/), se pronuncia igual que el nombre Jason, aunque Douglas Crockford, desarrollador del formato JSON, marca como tónica la segunda sílaba, como /dʒeɪˈsʌn/.[7]

En español, hay que tener en cuenta que JSON es una sigla y que en ocasiones no hay una sola forma de pronunciarlas. Atendiendo a la norma ortográfica,[8]​ lo normal sería pronunciarla como /xotaˈson/ (jotasón). Algunos lo pronuncian como /xaˈson/ (jasón), pero se alejaría más de la pronunciación de la sigla introduciendo una letra más que no existe en la sigla (JASON) y por tanto sería una pronunciación incorrecta. Otras personas prefieren pronunciar la sigla en español de manera similar al idioma inglés: /ˈʝei̯son/ (yéison).[9]

Sintaxis

[editar]

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 entre comillas dobles. El valor puede ser de cualquier tipo. Ejemplo:
{
  "departamento":8,
  "nombredepto":"Ventas",
  "director": "Juan Rodríguez",
  "empleados":[
    {
      "nombre":"Pedro",
      "apellido":"Fernández"
    },{
      "nombre":"Jacinto",
      "apellido":"Benavente"
    } 
  ]
}

Modelos de procesamiento

[editar]

Dado que el JSON es ampliamente utilizado para el intercambio de datos, se han desarrollado APIs para diversos lenguajes de programación, como 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.

Los modelos de programación más comunes para manipular JSON en diferentes lenguajes incluyen:[10]

  • Modelo de objeto: En este enfoque, el JSON completo se almacena en memoria en forma de árbol, lo que permite navegar, analizar y modificar el contenido utilizando las API adecuadas. Aunque este modelo consume más recursos al cargar todo en memoria, es altamente flexible para la manipulación de datos. Ejemplos de implementación incluyen la JSR 353 y la biblioteca Jackson en Java.
  • Modelo de flujo: Aquí, los datos se leen o escriben en bloques, generando eventos apropiados para indicar el tipo de bloque durante el proceso de lectura. El cliente puede procesar el contenido escuchando estos eventos, lo que le permite controlar cómo se lee el JSON, incluyendo la posibilidad de detener o saltar contenido durante el proceso. Este modelo también está permitido en Java a través de la JSR 353.
  • Conversión de objetos JSON a objetos del lenguaje: En este caso, las bibliotecas como Jackson y Gson en Java se encargan de convertir los objetos JSON en objetos del lenguaje de programación utilizado.

Uso de JSON

[editar]

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.

Un ejemplo de acceso a datos JSON usando XMLHttpRequest es:

var http_request = new XMLHttpRequest();
var url = "http://example.net/jsondata.php"; // Esta URL debería devolver datos JSON
 
// Descarga los datos JSON del servidor.
http_request.onreadystatechange = handle_json;
http_request.open("GET", url, true);
http_request.send(null);
 
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("Ocurrió 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.[11]

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.[12]

Hay una biblioteca[13]​ 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

[editar]

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": {
            "menuitems": [
                {
                    "value": "New", "onclick": "CreateNewDoc()"
                },{
                    "value": "Open", "onclick": "OpenDoc()"
                },{
                    "value": "Close", "onclick": "CloseDoc()"
                }
            ]
        }
    }
}

Es una posible representación JSON del siguiente XML:[14]

  <menu id="file" value="File">
    <popup>
      <menuitem value="New" onclick="CreateNewDoc()" />
      <menuitem value="Open" onclick="OpenDoc()" />
      <menuitem value="Close" onclick="CloseDoc()" />
    </popup>
  </menu>

Comparación con XML y otros lenguajes de marcado

[editar]

Hay muchos analizadores JSON en el lado del servidor, existiendo al menos un analizador para la mayoría de los entornos. En algunos lenguajes, como Java o PHP, hay diferentes implementaciones donde escoger. En JavaScript, el análisis es posible de manera nativa con la función JSON.parse(). Ambos formatos carecen de un mecanismo para representar grandes objetos binarios.

Con independencia de la comparación con XML, JSON puede ser muy compacto y eficiente si se usa de manera efectiva. Por ejemplo, la aplicación DHTML de búsqueda en «BarracudaDrive» (en inglés). Archivado desde el original el 21 de mayo de 2006.  recibe los listados de directorio como JSON desde el servidor. Esta aplicación de búsqueda está permanentemente consultando al servidor por nuevos directorios, y es notablemente rápida, incluso sobre una conexión lenta.

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.

Hay más comparaciones entre JSON y XML en JSON.org[15]

YAML es un superconjunto de JSON que trata de superar algunas de las limitaciones de este. Aunque es significativamente más complejo,[16]​ todavía 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.

Véase también

[editar]

Referencias

[editar]
  1. «JSON Parser: View and Edit JSON». jsonformatter.org (en inglés). 
  2. «AJAX without XML» [Comparación entre XML, JSON y objetos Javascript]. Software secret weapons (en inglés). Archivado desde el original el 7 de mayo de 2007. 
  3. «Speeding Up AJAX with JSON» [Muestra lo sencillo que es referenciar JSON en lugar de XML]. Developer (en inglés). 
  4. «Comunicación AJAX - PHP con JSON». webelop. Argentina. Archivado desde el original el 27 de agosto de 2008. «Muestra cómo obtener información en AJAX consultando un archivo PHP. Tiene en cuenta el problema de los caracteres especiales». 
  5. «JSON: The Fat-Free Alternative to XML». json.org (en inglés). 
  6. Yahoo!. «Using JSON with Yahoo! Web services». Archivado desde el original el 6 de enero de 2010. Consultado el 2 de marzo de 2010. 
  7. «Doug Crockford "Google Tech Talks: JavaScript: The Good Parts"». 7 de febrero de 2009. 
  8. RAE. «sigla | Diccionario panhispánico de dudas». «Diccionario panhispánico de dudas». Consultado el 25 de junio de 2021. 
  9. Kapić, Edin (15 de abril de 2016). «“Jotasón” y la (mala) pronunciación de términos informáticos». EdinKapic.com. Consultado el 2 de septiembre de 2018. 
  10. RESTful Java Web Services. Jobinesh Purushothaman. Packt Publishing, 2015. Segunda edición.
  11. «.json Extensión de archivo: Para qué son los archivos JSON?». abrirarchivos. Consultado el 22 de octubre de 2021. 
  12. «Animaciones para web con JSON». ramonubric. «Muestra como exportar animaciones con After Effects en formato JSON». 
  13. http://ajax.schwarz-interactive.de Archivado el 7 de marzo de 2011 en Wayback Machine.
  14. «Presentación útil de JSON». Emmerson Miranda. Archivado desde el original el 19 de noviembre de 2010. 
  15. «Página de ejemplo». JSON.org (en inglés). 
  16. Ippolito, Bob (19 de julio de 2005). «What happened to YAML?» [¿Qué pasó con YAML?] (en inglés). Archivado desde el original el 14 de febrero de 2012. Consultado el 22 de noviembre de 2012.