ホームページ >バックエンド開発 >PHPチュートリアル >`json_encode` 関数が PHP JSON 応答の description フィールドに NULL を返すのはなぜですか?

`json_encode` 関数が PHP JSON 応答の description フィールドに NULL を返すのはなぜですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-07 15:53:12265ブラウズ

Why is my `json_encode` function returning NULL for the description field in my PHP JSON response?

json_encode が説明フィールドに Null を返す

問題:

以下の PHP コードは、 JSON 応答の「説明」フィールドをエンコードし、NULL を返します

include('db.php');

$result = mysql_query('SELECT * FROM `staff` ORDER BY `id` DESC LIMIT 2') or die(mysql_error());
$rows = array();
while($row = mysql_fetch_assoc($result)){
    $rows[] = $row;
}

echo json_encode($rows);

データベース スキーマ:

CREATE TABLE `staff` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` longtext COLLATE utf8_unicode_ci,
  `description` longtext COLLATE utf8_unicode_ci,
  `icon` longtext COLLATE utf8_unicode_ci,
  `date` longtext COLLATE utf8_unicode_ci,
  `company` longtext COLLATE utf8_unicode_ci,
  `companyurl` longtext COLLATE utf8_unicode_ci,
  `appurl` longtext COLLATE utf8_unicode_ci,
  PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci

出力:

[{"id":"4","name":"Noter 2","description":null,"icon":"http:\/\/images.apple.com\/webapps\/productivity\/images\/noter2_20091223182720-thumb.jpg","date":"1262032317","company":"dBelement, LLC","companyurl":"http:\/\/dbelement.com\/","appurl":"http:\/\/noter2.dbelement.com"},{"id":"3","name":"Noter 2","description":null,"icon":"http:\/\/images.apple.com\/webapps\/productivity\/images\/noter2_20091223182720-thumb.jpg","date":"1262032317","company":"dBelement, LLC","companyurl":"http:\/\/dbelement.com\/","appurl":"http:\/\/noter2.dbelement.com"}]

ソリューション:

考えられる原因データが非 UTF8 エンコーディングを使用して取得されているということです。これを修正するには、SELECT クエリの前に次の行を追加します。

mysql_query('SET CHARACTER SET utf8');
これにより、データが UTF8 エンコードで取得されるようになり、json_encode で「description」フィールドを正しくエンコードできるようになります。

以上が`json_encode` 関数が PHP JSON 応答の description フィールドに NULL を返すのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。