JSON с PHP

В этой главе рассказывается, как кодировать и декодировать объекты JSON с помощью языка программирования PHP. Начнем с подготовки среды для программирования на PHP для JSON.

Окружающая обстановка

Начиная с PHP 5.2.0, расширение JSON по умолчанию входит в комплект и компилируется в PHP.

Функции JSON

Функция Библиотеки
json_encode Возвращает JSON-представление значения.
json_decode Расшифровывает строку JSON.
json_last_error Возвращает последнюю произошедшую ошибку.

Кодирование JSON в PHP (json_encode)

Функция PHP json_encode () используется для кодирования JSON в PHP. Эта функция возвращает JSON-представление значения в случае успеха или FALSE в случае неудачи.

Синтаксис

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

Параметры

  • value- Кодируемое значение. Эта функция работает только с данными в кодировке UTF-8.

  • options - Это необязательное значение представляет собой битовую маску, состоящую из JSON_HEX_QUOT, JSON_HEX_TAG, JSON_HEX_AMP, JSON_HEX_APOS, JSON_NUMERIC_CHECK, JSON_PRETTY_PRINT, JSON_UNESCAPED_SLASHES, JSON_FORCE_OBJECT.

пример

В следующем примере показано, как преобразовать массив в JSON с помощью PHP.

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

При выполнении это даст следующий результат -

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

В следующем примере показано, как объекты PHP могут быть преобразованы в 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);
?>

При выполнении это даст следующий результат -

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

Расшифровка JSON в PHP (json_decode)

Функция PHP json_decode () используется для декодирования JSON в PHP. Эта функция возвращает значение, декодированное из json в соответствующий тип PHP.

Синтаксис

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

Paramaters

  • json_string - Это закодированная строка, которая должна быть данными в кодировке UTF-8.

  • assoc - Это параметр логического типа, при значении TRUE возвращаемые объекты будут преобразованы в ассоциативные массивы.

  • depth - Параметр целочисленного типа, определяющий глубину рекурсии.

  • options - Это битовая маска целого типа декодирования JSON, поддерживается JSON_BIGINT_AS_STRING.

пример

В следующем примере показано, как можно использовать PHP для декодирования объектов JSON.

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

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

Во время выполнения он даст следующий результат -

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)
}