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

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

Barbara Streisand
Barbara Streisand원래의
2024-12-11 02:59:09828검색

Why Does My Symfony 3 App Get a

PDO MySQL 연결에서 알 수 없는 서버 문자 집합 오류

Symfony 3 응용 프로그램에서 MySQL 데이터베이스 연결을 설정하려고 하면 오류 메시지가 발생합니다. : "PDO::__construct(): 서버가 클라이언트에 알려지지 않은 문자 세트(255)를 보냈습니다. 개발자에게 보고하십시오." 이는 MySQL 서버가 PHP 클라이언트에 익숙하지 않은 문자 집합(255)을 전송하는 문제를 의미합니다.

배경:

이 오류는 MySQL 8.0에서 발생합니다. .1의 기본 문자 집합이 utf8mb4로 변환됩니다. 그러나 모든 클라이언트가 이 새 문자 집합을 인식할 수 있는 것은 아닙니다. 결과적으로 서버의 전송으로 인해 이 오류가 발생합니다.

해결책:

최적의 해결 방법은 클라이언트 소프트웨어를 업그레이드하는 것입니다. 그러나 임시 해결 방법은 다음과 같습니다.

  1. 이전 클라이언트와의 호환성을 보장하려면 MySQL 서버의 문자 집합을 utf8로 변경합니다.
  2. MySQL 구성 파일(/etc)에 다음 설정을 추가합니다. /my.cnf):
[client]
default-character-set=utf8

[mysql]
default-character-set=utf8


[mysqld]
collation-server = utf8_unicode_ci
character-set-server = utf8
  1. MySQL 서버 다시 시작 (mysqld)를 사용하여 이러한 변경 사항을 적용합니다.

추가 고려 사항:

  • PHP 클라이언트 버전이 7.1.33 이상인 경우에도 오류가 지속될 수 있습니다. 더 높습니다.
  • PDO 드라이버가 최신 버전으로 업데이트되었는지 확인하세요.
  • 데이터베이스 문자 집합이 UTF8로 설정되어 있는지 확인하세요.

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

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