Maison > titres > Jetez un œil à la gestion des erreurs JSON dans la nouvelle version de PHP 7.3

Jetez un œil à la gestion des erreurs JSON dans la nouvelle version de PHP 7.3

无忌哥哥
Libérer: 2018-07-12 11:39:34
original
3736 Les gens l'ont consulté

Contexte

Dans PHP V7.2 actuellement stable, si vous souhaitez déterminer que le JSON n'est pas valide, vous devez utiliser la vérification de la fonction json_last_error() :

>>> json_decode("{");
=> null
>>> json_last_error();
=> 4
>>> json_last_error() === JSON_ERROR_NONE
=> false
>>> json_last_error_msg()
=> "Syntax error"
Copier après la connexion

Par exemple, ici dans Larave se trouve une vérification pour s'assurer que l'appel de l'encodage JSON ne provoque pas d'erreur :

// Once we get the encrypted value we'll go ahead and base64_encode the input
// vector and create the MAC for the encrypted value so we can then verify
// its authenticity. Then, we'll JSON the data into the "payload" array.
$json = json_encode(compact('iv', 'value', 'mac'));
if (json_last_error() !== JSON_ERROR_NONE) {
    throw new EncryptException('Could not encrypt the data.');
}
return base64_encode($json);
Copier après la connexion

Nous pouvons au moins déterminer s'il y a une erreur dans l'encodage/décodage JSON, mais c'est un peu lourd, lève une exception, émet un code d'erreur et un message d'erreur.

Bien que vous disposiez déjà d'options pour capturer et traiter JSON, voyons ce que la nouvelle version peut faire de manière intéressante !

Lancement de drapeaux d'erreur dans PHP 7.3

Avec le nouveau drapeau d'option JSON_THROW_ON_ERROR, il est possible de réécrire ce bloc de code pour utiliser try/catch.

Peut-être quelque chose comme ceci :

use JsonException;
try {
    $json = json_encode(compact('iv', 'value', 'mac'), JSON_THROW_ON_ERROR);
    return base64_encode($json);
} catch (JsonException $e) {
    throw new EncryptException('Could not encrypt the data.', 0, $e);
}
Copier après la connexion

Je pense que ce nouveau style est particulièrement utile pour le code utilisateur lorsque vous recevez des données JSON au lieu de rechercher json_last_error() et les options correspondantes, l'encodage JSON et le décodage peut tirer parti des gestionnaires d'erreurs.

Cette fonction json_decode() prend quelques paramètres et ressemblera à PHP 7.3 et versions antérieures. Si vous souhaitez profiter de la gestion des erreurs :

use JsonException;
try {
    return json_decode($jsonString, $assoc = true, $depth = 512, JSON_THROW_ON_ERROR);
} catch (JsonException $e) {
    // Handle the JSON Exception
}
// Or even just let it bubble up...
/** 
 * Decode a JSON string into an array
 *
 * @return array
 * @throws JsonException
 */
function decode($jsonString) {
    return json_decode($jsonString, $assoc = true, $depth = 512, JSON_THROW_ON_ERROR);
}
Copier après la connexion

Récupérez le code d'erreur. et message d'erreur

Auparavant, vous receviez des codes d'erreur et des messages JSON en utilisant la fonction suivante :

// Error code
json_last_error();
// Human-friendly message
json_last_error_msg();
Copier après la connexion

Si vous utilisez le nouveau JSON_THROW_ON_ERROR, ici voici comment utiliser le code et recevoir des nouvelles :

try {
    return json_decode($jsonString, $assoc = true, $depth = 512, JSON_THROW_ON_ERROR);
} catch (JsonException $e) {
    $e->getMessage(); // like json_last_error_msg()
    $e->getCode(); // like json_last_error()
}
Copier après la connexion
Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal