json_last_error

(PHP 5 >= 5.3.0, PHP 7, PHP 8)

json_last_errorВозвращает последнюю ошибку

Описание

json_last_error(): int

Возвращает последнюю ошибку (если она есть), произошедшую во время последнего кодирования/декодирования JSON если при вызове не использовался флаг JSON_THROW_ON_ERROR.

Список параметров

У этой функции нет параметров.

Возвращаемые значения

Возвращает целочисленное значение, которое может быть одной из следующих констант:

Коды ошибок JSON
Константа Значение Доступность
JSON_ERROR_NONE Ошибок нет  
JSON_ERROR_DEPTH Достигнута максимальная глубина стека  
JSON_ERROR_STATE_MISMATCH Неверный или некорректный JSON  
JSON_ERROR_CTRL_CHAR Ошибка управляющего символа, возможно неверная кодировка  
JSON_ERROR_SYNTAX Синтаксическая ошибка  
JSON_ERROR_UTF8 Некорректные символы UTF-8, возможно неверная кодировка  
JSON_ERROR_RECURSION Одна или несколько зацикленных ссылок в кодируемом значении  
JSON_ERROR_INF_OR_NAN Одно или несколько значений NAN или INF в кодируемом значении  
JSON_ERROR_UNSUPPORTED_TYPE Передано значение с неподдерживаемым типом  
JSON_ERROR_INVALID_PROPERTY_NAME Имя свойства не может быть закодировано  
JSON_ERROR_UTF16 Некорректный символ UTF-16, возможно некорректно закодирован  

Примеры

Пример #1 Пример использования json_last_error()

<?php
// Верная json-строка
$json[] = '{"Organization": "PHP Documentation Team"}';

// Неверная json-строка, которая вызовет синтаксическую ошибку,
// здесь в качестве кавычек мы используем ' вместо "
$json[] = "{'Organization': 'PHP Documentation Team'}";


foreach (
$json as $string) {
echo
'Декодируем: ' . $string;
json_decode($string);

switch (
json_last_error()) {
case
JSON_ERROR_NONE:
echo
' - Ошибок нет';
break;
case
JSON_ERROR_DEPTH:
echo
' - Достигнута максимальная глубина стека';
break;
case
JSON_ERROR_STATE_MISMATCH:
echo
' - Некорректные разряды или несоответствие режимов';
break;
case
JSON_ERROR_CTRL_CHAR:
echo
' - Некорректный управляющий символ';
break;
case
JSON_ERROR_SYNTAX:
echo
' - Синтаксическая ошибка, некорректный JSON';
break;
case
JSON_ERROR_UTF8:
echo
' - Некорректные символы UTF-8, возможно неверно закодирован';
break;
default:
echo
' - Неизвестная ошибка';
break;
}

echo
PHP_EOL;
}
?>

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

Декодируем: {"Organization": "PHP Documentation Team"} - Ошибок нет
Декодируем: {'Organization': 'PHP Documentation Team'} - Синтаксическая ошибка, некорректный JSON

Пример #2 Совместное использование json_last_error() и json_encode()

<?php
// Некорректная последовательность UTF8
$text = "\xB1\x31";

$json = json_encode($text);
$error = json_last_error();

var_dump($json, $error === JSON_ERROR_UTF8);
?>

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

string(4) "null"
bool(true)

Пример #3 json_last_error() и JSON_THROW_ON_ERROR

<?php
// Некорректная последовательность UTF8, вызывающая JSON_ERROR_UTF8
json_encode("\xB1\x31");

// Не вызовет ошибки JSON
json_encode('okay', JSON_THROW_ON_ERROR);

// Глобальное состояние не будет изменено json_encode()
var_dump(json_last_error() === JSON_ERROR_UTF8);
?>

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

bool(true)

Смотрите также

  • json_last_error_msg() - Возвращает строку с сообщением об ошибке последнего вызова json_encode() или json_decode()
  • json_decode() - Декодирует строку JSON
  • json_encode() - Возвращает JSON-представление данных