Pourquoi `json_encode()` échoue-t-il avec des codes de continent spécifiques en PHP ?

Barbara Streisand
Libérer: 2024-11-03 23:22:30
original
865 Les gens l'ont consulté

Why Does `json_encode()` Fail with Specific Continent Codes in PHP?

Problèmes d'encodage JSON avec les tableaux PHP

Question :

J'utilise json_encode de PHP ( ) pour convertir les données de la table MySQL en JSON, mais je rencontre un comportement étrange. La fonction n'encode pas les données pour certaines requêtes, notamment celles contenant des caractères spéciaux ou certains codes de continent.

Extrait de code :

<code class="php">$result = mysqli_query($con, "SELECT * FROM countries WHERE continent_code='EU'") or die(mysqli_error($con));

while ($row = mysqli_fetch_array($result, MYSQLI_ASSOC)) {
    $orders[] = array(
        'CountryCode' => $row['code'],
        'CountryName' => $row['name']
    );
}

echo json_encode($orders);</code>
Copier après la connexion

Observation :

  • Le code encode correctement les données pour le code du continent « AS ».
  • Les codes du continent « EU », « NA », « AF » et autres ne produisent pas de JSON. sortie.

Problème :

La fonction json_encode() nécessite que toutes les données entrantes soient codées en UTF-8. Les caractères spéciaux et certains codes de continent peuvent ne pas être correctement encodés dans la base de données ou lors de la manipulation des données.

Solution :

Assurez l'encodage UTF-8 dans toute votre application Web. Cela inclut :

  • Configuration de la connexion à la base de données pour utiliser UTF-8 (par exemple, mysqli_set_charset($con, 'UTF-8'))
  • Déclaration de l'en-tête de la réponse JSON ( header('Content-Type: application/json; charset=utf-8');)
  • Vérifier que les fichiers PHP et la base de données utilisent l'encodage UTF-8 (par exemple, via l'encodage de fichier ou la configuration de la base de données)

Comme l'indique la RFC4627 : "Le texte JSON DEVRA être codé en Unicode. L'encodage par défaut est UTF-8." En assurant l'encodage UTF-8, json_encode() sera capable de traiter correctement toutes les données, quel que soit leur contenu.

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!

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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!