>백엔드 개발 >PHP 튜토리얼 >My Symfony 3 응용 프로그램에서 MySQL에 연결할 때 'PDO::__construct(): Server sent charset (255)known to the client' 오류가 발생하는 이유는 무엇입니까?

My Symfony 3 응용 프로그램에서 MySQL에 연결할 때 'PDO::__construct(): Server sent charset (255)known to the client' 오류가 발생하는 이유는 무엇입니까?

DDD
DDD원래의
2024-12-18 15:57:09859검색

Why Does My Symfony 3 Application Get a

PDO 알 수 없는 MySQL 문자 집합 딜레마

Symfony 3 애플리케이션을 통해 MySQL 데이터베이스에 연결하려고 하면 수수께끼 같은 오류가 발생할 수 있습니다. 메시지 "PDO::__construct(): 서버가 클라이언트에 알 수 없는 문자 세트(255)를 보냈습니다. 개발자." 이 문제는 서버의 기본 문자 집합과 클라이언트의 이해가 일치하지 않기 때문에 발생합니다.

배경

MySQL 버전 8.0.1에서는 기본 문자 집합을 utf8mb4로 변경했습니다. . 그러나 일부 클라이언트는 이러한 변경 사항을 인식하지 못합니다. 결과적으로 서버가 기본 문자 집합을 클라이언트에 전달할 때 인식할 수 없는 응답으로 인해 앞서 언급한 오류가 발생합니다.

해결 방법

최적의 솔루션은 클라이언트를 다음으로 업그레이드하는 것입니다. utf8mb4를 인식하는 버전입니다. 그러나 임시 조치로 업그레이드되지 않은 클라이언트를 수용하기 위해 서버의 문자 집합을 utf8로 수정할 수 있습니다. 이는 /etc/my.cnf에 다음 줄을 추가하여 수행됩니다.

[client]
default-character-set=utf8

[mysql]
default-character-set=utf8


[mysqld]
collation-server = utf8_unicode_ci
character-set-server = utf8

대체 솔루션

또 다른 잠재적 솔루션은 MySQL 연결 문자 집합을 강제로 설정하는 것입니다. 특정 값으로. PDO 연결 문자열에서 다음과 같은 charset 매개변수를 사용할 수 있습니다.

$dsn = "mysql:host=mysql;dbname=database;charset=utf8mb4;";

PDO 연결 문자열에서 charset를 명시적으로 정의하면 서버의 기본 문자 집합을 우회하고 업그레이드된 두 문자 집합과의 호환성을 보장할 수 있습니다. 업그레이드되지 않은 클라이언트.

위 내용은 My Symfony 3 응용 프로그램에서 MySQL에 연결할 때 'PDO::__construct(): Server sent charset (255)known to the client' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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