Java를 MySQL에 연결할 때 \'공개 키 검색이 허용되지 않습니다\' 예외를 해결하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-31 05:53:30
원래의
335명이 탐색했습니다.

How to Resolve the

연결 Java - MySQL: "공개 키 검색이 허용되지 않음" 예외 해결

다음을 사용하여 MySQL 데이터베이스에 연결을 설정하려고 할 때 Java 및 8.0.11 커넥터의 경우 사용자에게 다음 예외가 발생할 수 있습니다.

<code class="java">Exception in thread "main" java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed</code>
로그인 후 복사

해결 방법:

이 예외는 클라이언트가 공용 커넥터를 검색하려고 시도하고 있음을 나타냅니다. 키를 서버에서 가져오지만 공개 키 검색은 허용되지 않습니다. 이 문제를 해결하려면 MySQL 연결 문자열에allowPublicKeyRetrieval=true 옵션을 추가하여 공개 키 검색을 명시적으로 허용해야 합니다.

수정된 연결 관리자 클래스:

<code class="java">public static Connection getConnection() throws SQLException {
    
    MysqlDataSource dataSource = new MysqlDataSource();
    
    dataSource.setUseSSL( false );
    dataSource.setServerTimezone( serverTimeZone );
    dataSource.setServerName( serverName );
    dataSource.setDatabaseName( databaseName );
    dataSource.setPortNumber( portNumber );
    dataSource.setUser( user );
    dataSource.setPassword( password );
    
    // Allow public key retrieval
    dataSource.setAllowPublicKeyRetrieval( true );
    
    return dataSource.getConnection();
}</code>
로그인 후 복사

allowPublicKeyRetrieval을 true로 설정하면 클라이언트가 서버에 공개 키를 요청할 수 있는 권한이 부여됩니다. 이렇게 하면 "공개 키 검색이 허용되지 않습니다" 예외가 해결됩니다.

추가 고려 사항:

  • 공개 키 검색을 활성화하면 보안 위험에 노출될 수 있습니다. 테스트 또는 개발 후에는 비활성화하는 것이 좋습니다.
  • 또는 개발 목적으로만 useSSL=false를 설정하세요. SSL 암호화를 비활성화하므로 프로덕션 환경에서는 사용하지 마십시오.

위 내용은 Java를 MySQL에 연결할 때 \'공개 키 검색이 허용되지 않습니다\' 예외를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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