>백엔드 개발 >PHP 튜토리얼 >PHP JSON 응답의 설명 필드에 대해 `json_encode` 함수가 NULL을 반환하는 이유는 무엇입니까?

PHP JSON 응답의 설명 필드에 대해 `json_encode` 함수가 NULL을 반환하는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-07 15:53:12264검색

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가 "설명" 필드를 올바르게 인코딩할 수 있습니다.

위 내용은 PHP JSON 응답의 설명 필드에 대해 `json_encode` 함수가 NULL을 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.