JSON con PHP

Este capítulo cubre cómo codificar y decodificar objetos JSON utilizando el lenguaje de programación PHP. Comencemos por preparar el entorno para comenzar nuestra programación con PHP para JSON.

Medio ambiente

A partir de PHP 5.2.0, la extensión JSON se incluye y se compila en PHP de forma predeterminada.

Funciones JSON

Función Bibliotecas
json_encode Devuelve la representación JSON de un valor.
json_decode Decodifica una cadena JSON.
json_last_error Devuelve el último error ocurrido.

Codificación de JSON en PHP (json_encode)

La función PHP json_encode () se utiliza para codificar JSON en PHP. Esta función devuelve la representación JSON de un valor en caso de éxito o FALSO en caso de error.

Sintaxis

string json_encode ( $value [, $options = 0 ] )

Parámetros

  • value- El valor que se codifica. Esta función solo funciona con datos codificados en UTF-8.

  • options - Este valor opcional es una máscara de bits que consta de JSON_HEX_QUOT, JSON_HEX_TAG, JSON_HEX_AMP, JSON_HEX_APOS, JSON_NUMERIC_CHECK, JSON_PRETTY_PRINT, JSON_UNESCAPED_SLASHES, JSON_FORCE_OBJECT.

Ejemplo

El siguiente ejemplo muestra cómo convertir una matriz en JSON con PHP:

<?php
   $arr = array('a' => 1, 'b' => 2, 'c' => 3, 'd' => 4, 'e' => 5);
   echo json_encode($arr);
?>

Mientras se ejecuta, esto producirá el siguiente resultado:

{"a":1,"b":2,"c":3,"d":4,"e":5}

El siguiente ejemplo muestra cómo los objetos PHP se pueden convertir en JSON:

<?php
   class Emp {
      public $name = "";
      public $hobbies  = "";
      public $birthdate = "";
   }
	
   $e = new Emp();
   $e->name = "sachin";
   $e->hobbies  = "sports";
   $e->birthdate = date('m/d/Y h:i:s a', "8/5/1974 12:20:03 p");
   $e->birthdate = date('m/d/Y h:i:s a', strtotime("8/5/1974 12:20:03"));

   echo json_encode($e);
?>

Mientras se ejecuta, esto producirá el siguiente resultado:

{"name":"sachin","hobbies":"sports","birthdate":"08\/05\/1974 12:20:03 pm"}

Decodificación de JSON en PHP (json_decode)

La función PHP json_decode () se utiliza para decodificar JSON en PHP. Esta función devuelve el valor decodificado de json al tipo PHP apropiado.

Sintaxis

mixed json_decode ($json [,$assoc = false [, $depth = 512 [, $options = 0 ]]])

Parámetros

  • json_string - Es una cadena codificada que debe ser datos codificados en UTF-8.

  • assoc - Es un parámetro de tipo booleano, cuando se establece en TRUE, los objetos devueltos se convertirán en matrices asociativas.

  • depth - Es un parámetro de tipo entero que especifica la profundidad de recursividad.

  • options - Es una máscara de bits de tipo entero de decodificación JSON, se admite JSON_BIGINT_AS_STRING.

Ejemplo

El siguiente ejemplo muestra cómo se puede usar PHP para decodificar objetos JSON:

<?php
   $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}';

   var_dump(json_decode($json));
   var_dump(json_decode($json, true));
?>

Mientras se ejecuta, producirá el siguiente resultado:

object(stdClass)#1 (5) {
   ["a"] => int(1)
   ["b"] => int(2)
   ["c"] => int(3)
   ["d"] => int(4)
   ["e"] => int(5)
}

array(5) {
   ["a"] => int(1)
   ["b"] => int(2)
   ["c"] => int(3)
   ["d"] => int(4)
   ["e"] => int(5)
}