PHP8.3 aura de nouvelles fonctions ! (description de la fonction json_validate)

藏色散人
Libérer: 2023-04-11 09:58:01
avant
2202 Les gens l'ont consulté

Cet article vous apporte les dernières informations pertinentes sur php8.3. Il introduit principalement que PHP8.3 ajoutera une fonction appelée json_validate. Alors, à quoi sert cette fonction ? Comment l'utiliser ? Jetons-y un coup d'œil ensemble, j'espère que cela sera utile à tout le monde.

PHP8.3 aura de nouvelles fonctions ! (description de la fonction json_validate)

Aperçu PHP 8.3 : fonction `json_validate`

PHP 8.3 ajoutera une fonction nommée json_validate pour vérifier si la chaîne entrante est une chaîne JSON légale.

Actuellement, une manière courante de valider une chaîne JSON consiste à essayer de la décoder et de la déterminer en interceptant une exception. Mais dans certains cas, nous n’avons pas besoin d’obtenir un contenu spécifique, mais seulement de vérifier qu’il est légal. La nouvelle fonction json_validate consomme moins de mémoire et de ressources que json_decode car elle analyse uniquement la chaîne sans essayer de la décoder.

Signature de fonction

/**
 * 验证传入的字符串是否为合法 JSON 字符串
 *
 * @param string $json 准备验证的字符串
 * @param int $depth 最大嵌套深度,必须大于 0
 * @param int $flags 标志掩码,用于指定行为
 * @return bool $json 是合法 JSON 字符串时返回 true,否则返回 false
 */
function json_validate(string $json, int $depth = 512, int $flags = 0): bool {}
Copier après la connexion

Flags Flags

Le troisième paramètre de json_validate est flags, qui est utilisé pour spécifier le comportement de la fonction. Actuellement, le seul indicateur disponible est JSON_INVALID_UTF8_IGNORE.

Cet indicateur a été ajouté dans PHP 7.2 en tant que constante d'indicateur de json_decode, utilisé pour ignorer les caractères UTF-8 dans la chaîne correspondante.

json_validate('[1, 2, 3]', flags: JSON_INVALID_UTF8_IGNORE); // true

json_validate("[\"\xc1\xc1\",\"a\"]"); // false
json_validate("[\"\xc1\xc1\",\"a\"]", flags: JSON_INVALID_UTF8_IGNORE); // true
Copier après la connexion

Gestion des erreurs

json_validate lui-même ne renvoie pas de code d'erreur Si vous souhaitez obtenir des informations d'erreur spécifiques, vous pouvez utiliser json_last_error et json_last_error_msg pour les obtenir.

json_validate(""); // false

json_last_error(); // 4
json_last_error_msg(); // "Syntax error"
Copier après la connexion
json_validate("null"); // true

json_last_error(); // 0
json_last_error_msg(); // "No error"
Copier après la connexion

Exemple

Vérifiez la chaîne et lancez une exception

if (json_validate($_GET['json']) === false) {
    throw new \JsonException(json_last_error_msg(), json_last_error());
}
Copier après la connexion

Remplacez la méthode de vérification précédente

- $value = json_decode($_GET['json'], flags: JSON_THROW_ON_ERROR);
+ if (!json_validate($_GET['json'])) {
+   throw new \JsonException(json_last_error_msg(), json_last_error());
+ }
+ $value = json_decode($_GET['json']);
Copier après la connexion

Adaptation préemptive Polyfill

Si vous souhaitez vous adapter à PHP 8 .3 à l'avance, pour en toute transparence En passant à json_validate dès la sortie de la version 8.3, vous pouvez définir manuellement une fonction pour imiter l'effet de json_validate dans les versions précédentes.

if (!function_exists('json_validate')) {  
  function json_validate(string $json, int $depth = 512, int $flags = 0): bool {  
  if ($flags !== 0 && $flags !== \JSON_INVALID_UTF8_IGNORE) {  
  throw new \ValueError('json_validate(): Argument #3 ($flags) must be a valid flag (allowed flags: JSON_INVALID_UTF8_IGNORE)');  
  }  
  if ($depth <= 0 ) {  
  throw new \ValueError(&#39;json_validate(): Argument #2 ($depth) must be greater than 0&#39;);  
  }  
  \json_decode($json, null, $depth, $flags);  
  return \json_last_error() === \JSON_ERROR_NONE;  
  }  
}
Copier après la connexion

Étant donné que cette fonction utilise toujours json_decode en interne, elle n'a en fait aucune amélioration des performances, mais fournit uniquement une interface similaire à json_validate.

Apprentissage recommandé : "Tutoriel vidéo PHP"

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:learnku.com
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