PHP 5.3.0에서 원격 MySQL 5.0.22 데이터베이스에 연결할 때 MySQL_connect()가 \'예상보다 6바이트 짧은 OK 패킷\'과 함께 실패하는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-07 05:10:02
원래의
167명이 탐색했습니다.

Why does MySQL_connect() fail with

MySQL PHP 비호환성: 오류 이해

질문에 설명된 문제는 로컬에서 원격 MySQL 데이터베이스에 연결하려고 할 때 발생합니다. PHP 5.3.0을 실행하는 WAMP 설치. MySQL 5.0.45를 실행하는 데이터베이스에 연결하는 데 성공했지만 버전 5.0.22를 사용하여 데이터베이스에 연결하면 다음 오류가 발생합니다.

Warning: mysql_connect() [function.mysql-connect]: OK packet 6 bytes shorter than expected. PID=5880 in ...
Warning: mysql_connect() [function.mysql-connect]: mysqlnd cannot connect to MySQL 4.1+ using old authentication in ...
로그인 후 복사

설명

이러한 비호환성의 근본 원인은 연결에 사용되는 MySQL 계정의 비밀번호 길이에서 비롯됩니다. 일반적으로 이전 버전으로 생성된 MySQL 계정은 16자 비밀번호를 사용했습니다. 그러나 PHP 5.3.0과 같은 최신 버전의 PHP에서는 더 이상 이전 비밀번호를 사용한 인증을 지원하지 않습니다.

해결 방법

문제를 해결하려면 영향을 받은 MySQL 계정은 다음과 같은 명령을 사용하여 재설정해야 합니다.

SET PASSWORD FOR 'username'@'hostmask' = PASSWORD('thepassword')
로그인 후 복사

또한 서버가 기본적으로 이전 비밀번호를 사용하거나 생성하도록 구성되어 있는지 확인하는 것이 좋습니다.

진단 쿼리

문제를 추가로 진단하려면 문제가 있는 MySQL 서버에서 다음 쿼리를 실행하여 비밀번호 길이를 확인할 수 있습니다.

SELECT
  Length(`Password`),
  Substring(`Password`, 1, 1)
FROM
  `mysql`.`user`
WHERE
  `user`='username'
로그인 후 복사

'사용자 이름'을 다음으로 바꾸세요. 데이터베이스 연결에 사용되는 실제 사용자 이름은 비밀번호 길이와 비밀번호의 첫 문자에 대한 정보를 제공하므로 기존 비밀번호인지 확인하는 데 도움이 됩니다.

위 내용은 PHP 5.3.0에서 원격 MySQL 5.0.22 데이터베이스에 연결할 때 MySQL_connect()가 \'예상보다 6바이트 짧은 OK 패킷\'과 함께 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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