json_last_error

(PHP 5 >= 5.3.0, PHP 7)

json_last_errorDevuelve el último error ocurrido

Descripción

json_last_error ( void ) : int

Devuelve el último error (si existe) que ocurrió durante la última codificación/decodificación JSON.

Parámetros

Esta función no tiene parámetros.

Valores devueltos

Devuelve un integer, que puede ser una de las siguientes constantes:

Códigos de error de JSON
Constante Significado Disponibilidad
JSON_ERROR_NONE No ocurrió ningún error  
JSON_ERROR_DEPTH Se ha excedido la profundidad máxima de la pila  
JSON_ERROR_STATE_MISMATCH JSON con formato incorrecto o inválido  
JSON_ERROR_CTRL_CHAR Error del carácter de control, posiblemente se ha codificado de forma incorrecta  
JSON_ERROR_SYNTAX Error de sintaxis  
JSON_ERROR_UTF8 Caracteres UTF-8 mal formados, posiblemente codificados de forma incorrecta PHP 5.3.3
JSON_ERROR_RECURSION Una o más referencias recursivas en el valor a codificar PHP 5.5.0
JSON_ERROR_INF_OR_NAN Uno o más valores NAN o INF en el valor a codificar PHP 5.5.0
JSON_ERROR_UNSUPPORTED_TYPE Se proporcionó un valor de un tipo que no se puede codificar PHP 5.5.0
JSON_ERROR_INVALID_PROPERTY_NAME Se dio un nombre de una propiedad que no puede ser codificada PHP 7.0.0
JSON_ERROR_UTF16 Caracteres UTF-16 malformados, posiblemente codificados de forma incorrecta PHP 7.0.0

Ejemplos

Ejemplo #1 Ejemplo de json_last_error()

<?php
// Un string json válido
$json[] = '{"Organización": "Equipo de documentación PHP"}';

// Un string json no válido que causa un error de sintaxis, en este caso, se ha
// usado ' en vez de " para entrecomillar
$json[] = "{'Organización': 'Equipo de documentación PHP'}";


foreach(
$json as $string) {
    echo 
'Decodificando: ' $string;
    
json_decode($string);

    switch(
json_last_error()) {
        case 
JSON_ERROR_NONE:
            echo 
' - Sin errores';
        break;
        case 
JSON_ERROR_DEPTH:
            echo 
' - Excedido tamaño máximo de la pila';
        break;
        case 
JSON_ERROR_STATE_MISMATCH:
            echo 
' - Desbordamiento de buffer o los modos no coinciden';
        break;
        case 
JSON_ERROR_CTRL_CHAR:
            echo 
' - Encontrado carácter de control no esperado';
        break;
        case 
JSON_ERROR_SYNTAX:
            echo 
' - Error de sintaxis, JSON mal formado';
        break;
        case 
JSON_ERROR_UTF8:
            echo 
' - Caracteres UTF-8 malformados, posiblemente codificados de forma incorrecta';
        break;
        default:
            echo 
' - Error desconocido';
        break;
    }

    echo 
PHP_EOL;
}
?>

El resultado del ejemplo sería:

Decoding: {"Organización": "Equipo de documentación PHP"} - Sin errores
Decoding: {'Organización': 'Equipo de documentación PHP'} - Error de sintaxis, JSON mal formado

Ejemplo #2 json_last_error() en json_encode()

<?php
// Secuencia inválida UTF8
$text "\xB1\x31";

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

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

El resultado del ejemplo sería:

string(4) "null"
bool(true)

Ver también