P粉7901875072023-08-22 19:20:43
chazomaticus의 탁월한 답변에 한 가지 점을 더 추가하고 싶습니다.
또한 META 태그(예: HTML4 또는 XHTML 버전 )도 잊지 마세요.
으아아아사소해 보일 수도 있지만 이전에는 IE7에서 문제가 발생했습니다.
모든 작업을 올바르게 수행하고 있습니다. 데이터베이스, 데이터베이스 연결 및 Content-Type HTTP 헤더는 모두 UTF-8로 설정되어 있으며 다른 모든 브라우저에서는 잘 작동하지만 Internet Explorer에서는 여전히 "서유럽" 인코딩을 사용해야 합니다.
페이지에 META 태그가 누락된 것으로 나타났습니다. 추가한 후 문제가 해결되었습니다.
편집자:
W3C에는 실제로 국제화(I18N)를 전담하는 다소 큰 섹션이 있습니다. 이 문제와 관련된 많은 기사가 있습니다. HTTP, (X)HTML 및 CSS의 측면을 설명합니다.
HTTP 헤더와 HTML 메타 태그(또는 XML로 제공되는 XHTML의 경우 XML 선언)를 모두 사용하는 것이 좋습니다.
P粉6530458072023-08-22 18:34:47
데이터 저장:
데이터베이스의 모든 테이블과 텍스트 열에 utf8mb4
字符集。这样,MySQL会以UTF-8的原生编码方式物理存储和检索值。请注意,如果指定了utf8mb4_*
排序规则(而没有明确指定字符集),MySQL将隐式使用utf8mb4
인코딩을 지정하세요.
이전 버전의 MySQL(<5.5.3)에서는 유니코드 문자의 하위 집합만 지원하는 utf8
만 사용할 수 있었습니다. 농담이기를 바랍니다.
데이터 액세스:
애플리케이션 코드(예: PHP)에서는 어떤 데이터베이스 액세스 방법을 사용하든 연결 문자 집합을 utf8mb4
로 설정해야 합니다. 이런 방식으로 MySQL은 데이터를 애플리케이션에 전달할 때 데이터 변환을 수행하지 않으며 그 반대의 경우도 마찬가지입니다.
일부 드라이버는 자체 내부 상태를 업데이트하고 연결에 사용할 인코딩을 MySQL에 알리는 연결 문자 집합을 구성하는 자체 메커니즘을 제공합니다. 이는 일반적으로 선호되는 방법입니다. PHP에서:
mysqli를 사용하는 경우 set_charset()
로 전화할 수 있습니다.
순수한 mysql에 갇혀 있지만 PHP ≥ 5.2.3을 실행 중인 경우 mysql_set_charset
을 호출할 수 있습니다.
드라이버가 연결 문자 집합 설정을 위한 자체 메커니즘을 제공하지 않는 경우 애플리케이션이 연결에서 데이터 인코딩을 처리하는 방법을 MySQL에 알리는 쿼리를 실행해야 할 수도 있습니다: SET NAMES 'utf8mb4'
.
위의 utf8mb4
/utf8
/
출력
:🎜Content-Type: text/html; charset=utf-8
。你可以通过在php.ini中设置default_charset
(首选)或手动使用header()
함수 등을 사용하여 HTTP 헤더에 설정되어야 합니다. json_encode()
编码输出时,将JSON_UNESCAPED_UNICODE
를 사용하여 추가합니다. 들어가세요 :
mb_check_encoding()
은 이 문제를 해결할 수 있지만 계속해서 노력해야 합니다. 악의적인 클라이언트가 원하는 인코딩으로 데이터를 제출할 수 있기 때문에 이 문제를 해결할 수 있는 방법이 없으며 PHP가 이를 수행하도록 안정적으로 수행할 수 있는 방법을 찾지 못했습니다. 기타 코드 노트:
제공하는 모든 파일(PHP, HTML, JavaScript 등)은 유효한 UTF-8로 인코딩되어야 합니다.
UTF-8 문자열을 처리할 때마다 안전하게 처리하는지 확인해야 합니다. 불행히도 이것은 어려운 부분입니다. 아마도 PHP의 mbstring
확장 기능을 많이 사용하실 것입니다.
PHP의 내장 문자열 작업은 기본적으로 UTF-8 안전하지 않습니다. 연결과 같은 일반적인 PHP 문자열 작업을 사용하여 일부 작업을 안전하게 수행할 수 있지만 대부분의 경우에는 동등한 mbstring
함수를 사용해야 합니다.
무엇을 하고 있는지(즉, 망치지 않으려면) UTF-8과 UTF-8이 가장 낮은 수준에서 어떻게 작동하는지 이해해야 합니다. utf8.com에는 알아야 할 모든 것을 배울 수 있는 훌륭한 리소스가 있습니다.