首頁 >Java >java教程 >如何解決Java SFTP(JSch)中的'UnknownHostKey”錯誤?

如何解決Java SFTP(JSch)中的'UnknownHostKey”錯誤?

Barbara Streisand
Barbara Streisand原創
2024-12-02 00:18:10896瀏覽

How to Solve the

了解 Java SFTP (JSch) 中的 UnknownHostKey 錯誤

您在使用 Java SFTP 函式庫 JSch 時遇到「UnknownHost」錯誤。此錯誤表明 JSch 無法驗證遠端主機公鑰的真實性。要解決此問題,必須了解其根本原因。

原因:

當 JSch 連接到遠端主機時,它將主機的公鑰與清單進行比較已知主機金鑰。如果在已知主機清單中找不到遠端主機的金鑰,則提示使用者確認並詢問是否將該金鑰新增至清單。預設情況下,JSch 的「StrictHostKeyChecking」處於啟用狀態,這會阻止其自動連線到具有未知或未經驗證金鑰的主機。

解決方案:

1.忽略主機金鑰驗證(不建議):

Properties config = new Properties();
config.put("StrictHostKeyChecking", "no");
session.setConfig(config);

這種方法允許JSch 在不檢查主機金鑰的情況下連接到遠端主機,這不是安全的做法,只能在受信任的情況下使用環境。它不能解決問題的根本原因。

2.設定主機金鑰驗證:

選項1:使用已知主機檔案

JSch.setKnownHosts("/path/to/known_hosts");

此檔案包含已知主機金鑰及其對應指紋的清單。連接到遠端主機時,JSch 會將主機的公鑰與已知主機檔案中的金鑰進行比較。如果找到匹配項,則無需用戶確認即可繼續連線。

選項2:手動新增主機金鑰

HostKey knownHostKey = new HostKey("127.0.0.1", 22, "rsa", "A2:39:3F:44:88:E9:1F:D7:D1:71:F4:85:98:FB:90:DC");
session.getHostKeyRepository().add(knownHostKey, session);

此方法可讓您手動提供預期的主機金鑰遠端主機的主機金鑰,允許JSch 在沒有任何用戶提示的情況下驗證連線。

透過實作這兩種方法之一,您可以解決「UnknownHostKey」錯誤並與遠端主機建立安全的 SFTP 連線。

以上是如何解決Java SFTP(JSch)中的'UnknownHostKey”錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn