PHP の json_encode による JSON エンコーディングの不規則性
この問題は、PHP の json_encode() 関数を使用してデータベース テーブル データを JSON にエンコードしようとすると発生します。興味深いことに、動作は入力データに基づいて異なります。
「SELECT FROM 国 WHEREcontinent_code='AS'」のようなクエリは正常に JSON 値を返しますが、「SELECT FROM 国」などのクエリは正常に JSON 値を返します。 WHEREcontinent_code='EU'" の場合、これを実行できません。驚くべきことに、「EU」、「NA」、「AF」などの大陸コードは、他の大陸コードとは異なる動作をします。
コードを調べると、問題は json_encode() 関数内にあることがわかります。
<code class="php">while ($row = mysqli_fetch_array($result, MYSQLI_ASSOC)) { $orders[] = array( 'CountryCode' => $row['code'], 'CountryName' => $row['name'] ); } echo json_encode($orders);</code>
データは、json_encode() に渡される前に $orders 配列に正常に入力されます。ただし、関数は特定の大陸コードのエンコードに失敗します。
この問題を解決する鍵は、Web アプリケーション全体で UTF-8 エンコードを確実に行うことにあります。
これらのガイドラインに従うことで、JSON エンコードの不規則性を解決し、一貫した動作を保証できます。すべての入力データのコード。
以上がPHP の json_encode 関数のエンコード データが大陸コードに基づいて一貫性がないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。