집 >데이터 베이스 >MySQL 튜토리얼 >PHP에서 데이터베이스 행을 인코딩할 때 json_encode()가 때때로 UTF-8 문자를 잃는 이유는 무엇입니까?
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>
이 업데이트된 코드에서는
이 접근 방식을 사용하면 최종 JSON 인코딩 전에 모든 UTF-8 문자가 올바르게 인코딩되어 원본 코드에서 일부 문자가 손실되거나 null로 나타나는 문제가 해결됩니다. .
위 내용은 PHP에서 데이터베이스 행을 인코딩할 때 json_encode()가 때때로 UTF-8 문자를 잃는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!