PHP에서 데이터베이스 행을 인코딩할 때 json_encode()가 때때로 UTF-8 문자를 잃는 이유는 무엇입니까?

DDD
풀어 주다: 2024-10-30 20:56:30
원래의
570명이 탐색했습니다.

Why Does json_encode() Sometimes Lose UTF-8 Characters When Encoding Database Rows in PHP?

json_encode()의 UTF-8 문자 인코딩 문제

PHP에서는 특히 작업할 때 UTF-8 문자 인코딩을 처리하는 것이 어려울 수 있습니다. 데이터베이스와 JSON 인코딩을 사용합니다. 악센트 문자가 있는 데이터베이스 행이 포함된 배열을 JSON으로 인코딩하려고 할 때 한 가지 일반적인 문제가 발생합니다. json_encode()가 UTF-8을 지원한다고 주장하는 문서에도 불구하고 인코딩 프로세스 중에 일부 문자가 손실되거나 null 값으로 나타날 수 있습니다.

이 문제를 해결하려면 대체 접근 방식이 필요합니다. 행 배열을 직접 인코딩하는 대신 빈 배열을 만들고 행별로 인코딩된 값으로 채웁니다. 예는 다음과 같습니다.

<code class="php">// Create an empty array for the encoded resultset
$rows = array();

// Loop over the db resultset and put encoded values into $rows
while($row = mysql_fetch_assoc($result)) {
  $rows[] = array_map('utf8_encode', $row);
}

// Output $rows
echo json_encode($rows);</code>
로그인 후 복사

이 업데이트된 코드에서는

  1. 빈 배열($rows)이 초기화되어 인코딩된 결과 집합을 보유합니다.
  2. 행이 반복되고 각 행은 array_map()을 통해 전달되어 개별 값을 인코딩합니다.
  3. 인코딩된 값은 $rows 배열에 저장됩니다.
  4. 마지막으로 인코딩된 $rows 배열은 다음과 같습니다. JSON으로 인코딩되어 출력됩니다.

이 접근 방식을 사용하면 최종 JSON 인코딩 전에 모든 UTF-8 문자가 올바르게 인코딩되어 원본 코드에서 일부 문자가 손실되거나 null로 나타나는 문제가 해결됩니다. .

위 내용은 PHP에서 데이터베이스 행을 인코딩할 때 json_encode()가 때때로 UTF-8 문자를 잃는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!