Verification: a143cc29221c9be0

Php array data from mysql

Что такое JSON

JSON расшифровывается как аббревиатура от J ava S cript O bject N otation. JSON — это стандартный текстовый формат обмена данными, основанный на JavaScript, который представляет собой набор пар {ключ: значение}.

В JSON, ключи всегда строки, в то время как значение может быть string, number, true или false, null, object или array. Строки должны быть заключены в двойные кавычки "и могут содержать управляющие символы, такие как \n, \tи \. JSON более компактный, чем xml, поэтому он более предпочтителен для обмена данными между веб-браузером и сервером.

Синтаксис JSON на примерах

Объект JSON может выглядеть так:

Пример

{
  "ФИО" : "Иванов Иван",
  "Адрес" : {
    "Город" : "Киров",
    "Улица" : "Вербицкого",
    "Дом" : "7"
  }
}

В то время как пример массива JSON будет выглядеть примерно так:

Пример

{
    "smarts": [
        "Apple",
        "ASUS",
        "Huawei",
        "Lenovo"
    ]
}

PHP и JSON

Структуры данных JSON очень похожи на массивы PHP. В языке PHP существуют специальные функции для кодирования и декодирования данных JSON. Это функции json_encode() и json_decode() соответственно. Они уже встроены в ядро PHP, поэтому никаких библиотек подключать не нужно. Обе функции работают только со строковыми данными в кодировке UTF-8.

Кодирование данных JSON в PHP

В PHP функция json_encode() используется для кодирования значения в формат JSON. Кодируемое значение может быть любым типом данных PHP, кроме ресурса, такого как база данных или дескриптор файла.

Синтаксис

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

Параметры

value
- значение, которое будет закодировано. Может быть любого типа за исключением resource. Все строковые данные должны быть в кодировке 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_UNESCAPED_UNICODE.
depth
Задает максимальную глубину. Должен быть больше нуля.

В приведенном ниже примере показано, как кодировать ассоциативный массив PHP в объект JSON:

65, "Harry"=>80, "John"=>78, "Clark"=>90);
 
echo json_encode($marks);
?>

Результат приведенного выше примера будет выглядеть так:

{"Peter": 65, "Harry": 80, "John": 78, "Clark": 90}

В следующем примере посмотрим, как будут кодироваться кириллические символы:

65, "Игорь"=>80, "Денис"=>78, "Николай"=>90);
 
echo json_encode($marks);
?>

Результат приведенного выше примера будет выглядеть так:

{"\u041f\u0451\u0442\u0440":65,"\u0418\u0433\u043e\u0440\u044c":80,"\u0414\u0435\u043d\u0438\u0441":78,"\u041d\u0438\u043a\u043e\u043b\u0430\u0439":90}

Как видно кириллица кодируется, исправляется это добавлением опции: JSON_UNESCAPED_UNICODE.

65, "Игорь"=>80, "Денис"=>78, "Николай"=>90);
 
echo json_encode($marks, JSON_UNESCAPED_UNICODE);
?>

Результат выполнения кода:

{"Пётр": 65, "Игорь": 80, "Денис": 78, "Николай": 90}

Точно так же вы можете закодировать индексированный массив PHP в массив JSON, например:

В следующем примере посмотрим, как будут кодироваться кириллические символы:

Результат выполнения кода:

["Красный","Зелёный","Синий","Оранжевый","Жёлтый"]

Если применить параметр JSON_FORCE_OBJECT, то функция json_encode() будет возвращать индексированный массив PHP как объект JSON:

Результат выполнения кода:

{"0":"Apple","1":"ASUS","2":"Huawei","3":"Lenovo","4":"Samsung"}

Примечание: Неассоциативный массив может быть закодирован как массив или объект. Однако ассоциативный массив всегда кодируется как объект.

Декодирование данных JSON в PHP

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

Синтаксис

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

Параметры

json
- json строка (string) для декодирования. Эта функция работает только со строками в UTF-8 кодировке.
assoc
Если TRUE, возвращаемые объекты будут преобразованы в ассоциативные массивы.
depth
Указывает глубину рекурсии.
options
Битовая маска опций декодирования JSON. В настоящий момент поддерживается только JSON_BIGINT_AS_STRING (по умолчанию большие целые числа приводятся к числам с плавающей запятой (float))

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

Результат выполнения кода:

object(stdClass)#1 (4) { ["Peter"]=> int(65) ["Harry"]=> int(80) ["John"]=> int(78) ["Clark"]=> int(90) }

Функция json_decode() по умолчанию возвращает объект. Если нужно JSON декодировать в ассоциативный массив, то укажите значение второго параметра $assoc в качестве true. По умолчанию его значение — false:

Результат выполнения кода:

array(4) { ["Peter"]=> int(65) ["Harry"]=> int(80) ["John"]=> int(78) ["Clark"]=> int(90) }

Доступ к декодированным значениям JSON в PHP

Теперь рассмотрим пример, который показывает, как декодировать данные JSON и получить доступ к отдельным элементам объекта JSON в PHP:

Peter; // вывод 35
echo $obj->Ben;   // вывод 37
echo $obj->Joe;   // вывод 43
?>

В этом примере показано, как получить доступ к отдельным элементам ассоциативного массива PHP:

Вы также можете перебирать декодированные данные с помощью цикла foreach(), например:

$value){
    echo $key . "=>" . $value . "
"; } echo "
"; // Декодируем данные JSON в объект PHP $obj = json_decode($json); // Перебираем в цикле значения объекта foreach($obj as $key=>$value){ echo $key . "=>" . $value . "
"; } ?>