java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed
在使用 MySQL 8.0 或更高版本時,可能會遇到以下錯誤:java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed
這是因?yàn)?MySQL 8.0 默認(rèn)啟用了 caching_sha2_password 插件,而 JDBC 驅(qū)動默認(rèn)不允許檢索公鑰。以下是幾種常見的解決方法:
解決方案一:修改數(shù)據(jù)庫連接字符串
在 JDBC 連接 URL 中添加 allowPublicKeyRetrieval=true 參數(shù):
jdbc:mysql://localhost:3306/your_database?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC
- allowPublicKeyRetrieval=true:允許檢索公鑰。
- useSSL=false:禁用 SSL,視需求而定。
解決方案二:修改 MySQL 用戶認(rèn)證插件
ALTER USER 'your_user'@'your_host' IDENTIFIED WITH mysql_native_password BY 'your_password';
解決方案三:更新 MySQL JDBC 驅(qū)動
確保使用最新版的 MySQL JDBC 驅(qū)動,以避免與 MySQL 8.0 的認(rèn)證方式不兼容
Maven 示例:
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.30</version>
</dependency>
總結(jié)
- 如果不想修改認(rèn)證插件,使用 allowPublicKeyRetrieval=true 解決問題。
- 可以修改用戶認(rèn)證插件為 mysql_native_password,或更新 JDBC 驅(qū)動。
到此這篇關(guān)于java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed的文章就介紹到這了,更多相關(guān)java.sql.SQLNonTransientConnectionException內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- mysql字符集引起的java.sql.SQLException:Incorrect?string?value:問題
- java中java.util.Date和java.sql.Date之間的轉(zhuǎn)換的示例
- 解決rror updating database.Cause:java.sql.SQLSyntaxErrorException問題
- java.sql.SQLRecoverableException關(guān)閉的連接異常問題及解決辦法
- 解決java.sql.SQLException:The?server?time?zone?value?'?D1ú±ê×?ê±??'?is?unrecognized問題
- java.sql.SQLException:?connection?holder?is?null錯誤解決辦法
相關(guān)文章
JavaWeb Servlet實(shí)現(xiàn)網(wǎng)頁登錄功能
這篇文章主要為大家詳細(xì)介紹了JavaWeb Servlet實(shí)現(xiàn)網(wǎng)頁登錄功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-07-07
Spring:@Async注解和AsyncResult與CompletableFuture使用問題
這篇文章主要介紹了Spring:@Async注解和AsyncResult與CompletableFuture使用問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
使用java實(shí)現(xiàn)備份和恢復(fù)SQLServer表數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了如何使用java實(shí)現(xiàn)備份和恢復(fù)SQLServer表數(shù)據(jù),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01
Java多線程并發(fā)生產(chǎn)者消費(fèi)者設(shè)計模式實(shí)例解析
這篇文章主要介紹了Java多線程并發(fā)生產(chǎn)者消費(fèi)者設(shè)計模式實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-03-03

