如何在java中使用SFTP協(xié)議安全的傳輸文件
本文介紹在Java中如何使用基于SSH的文件傳輸協(xié)議(SFTP)將文件從本地上傳到遠(yuǎn)程服務(wù)器,或者將文件在兩個服務(wù)器之間安全的傳輸。我們先來了解一下這幾個協(xié)議
- SSH 是較可靠,專為遠(yuǎn)程登錄會話和其他網(wǎng)絡(luò)服務(wù)提供安全性的協(xié)議。比如:我們購買的云服務(wù)器登陸的時候使用的協(xié)議都是ssh。
- ftp協(xié)議通常是用來在兩個服務(wù)器之間傳輸文件的,但是它本質(zhì)上是不安全的。
- 那么SFTP是什么?SFTP可以理解為SSH + FTP,也就是安全的網(wǎng)絡(luò)文件傳輸協(xié)議。
一般來說,SFTP和FTP服務(wù)都是使用相應(yīng)的客戶端軟件來提供服務(wù)。如果你希望在java代碼中使用SFTP協(xié)議進(jìn)行安全的文件傳輸,那么這篇文章非常適合你。
1. 導(dǎo)入JSch 依賴包
在maven項(xiàng)目pom.xml中導(dǎo)入如下的坐標(biāo),我們使用JSch,JSch將SFTP協(xié)議封裝為對應(yīng)的API供我們調(diào)用。
<dependency> <groupId>com.jcraft</groupId> <artifactId>jsch</artifactId> <version>0.1.55</version> </dependency>
2. 文件傳輸 – JSch例子
2.1 get與put方法
在JSch
,我們可以使用put
和get
在服務(wù)器之間進(jìn)行文件傳輸。put
方法用來將文件從本地系統(tǒng)傳輸?shù)竭h(yuǎn)程服務(wù)器。
channelSftp.put(localFile, remoteFile);
get方法將文件從遠(yuǎn)程服務(wù)器下載到本地系統(tǒng)。
channelSftp.get(remoteFile, localFile);
2.2 使用用戶名和密碼進(jìn)行認(rèn)證
JSch jsch = new JSch(); jsch.setKnownHosts("/home/zimug/.ssh/known_hosts"); jschSession = jsch.getSession(USERNAME, REMOTE_HOST, REMOTE_PORT); jschSession.setPassword(PASSWORD);
- "/home/zimug/.ssh/known_hosts"為SSH的known_hosts文件,也就是可信遠(yuǎn)程主機(jī)的公鑰保存文件。
- USERNAME 為用戶名
- REMOTE_HOST遠(yuǎn)程主機(jī)的Ip
- REMOTE_PORT遠(yuǎn)程主機(jī)端口
- PASSWORD遠(yuǎn)程主機(jī)登錄密碼
2.3.使用公鑰和私鑰進(jìn)行認(rèn)證
如果讀者不能理解公鑰和私鑰的用法及含義,需要先自行補(bǔ)充一下SSH知識。
- 本地私鑰–/home/登錄用戶名/.ssh/id_rsa
- 遠(yuǎn)程公鑰默認(rèn)保存位置–~/.ssh/authorized_keys
JSch jsch = new JSch(); jsch.setKnownHosts("/home/zimug/.ssh/known_hosts"); jschSession = jsch.getSession(USERNAME, REMOTE_HOST, REMOTE_PORT); jsch.addIdentity("/home/zimug/.ssh/id_rsa");
2.4 完整JSch文件傳輸示例
將文件從本地系統(tǒng)傳輸?shù)竭h(yuǎn)程服務(wù)器1.2.3.4
,并使用SSH密碼登陸方式進(jìn)行身份驗(yàn)證。
import com.jcraft.jsch.*; public class SFTPFileTransfer { private static final String REMOTE_HOST = "1.2.3.4"; //遠(yuǎn)程主機(jī)ip private static final String USERNAME = ""; //登錄用戶名 private static final String PASSWORD = ""; //登陸密碼 private static final int REMOTE_PORT = 22; //ssh協(xié)議默認(rèn)端口 private static final int SESSION_TIMEOUT = 10000; //session超時時間 private static final int CHANNEL_TIMEOUT = 5000; //管道流超時時間 public static void main(String[] args) { String localFile = "/home/zimug/local/random.txt"; //本地文件路徑 String remoteFile = "/home/zimug/remote/targetfile.txt"; //上傳到遠(yuǎn)程的文件路徑,要保證登錄用戶有寫權(quán)限 Session jschSession = null; try { JSch jsch = new JSch(); jsch.setKnownHosts("/home/zimug/.ssh/known_hosts"); jschSession = jsch.getSession(USERNAME, REMOTE_HOST, REMOTE_PORT); // 通過ssh私鑰的方式登錄認(rèn)證 // jsch.addIdentity("/home/zimug/.ssh/id_rsa"); // 通過密碼的方式登錄認(rèn)證 jschSession.setPassword(PASSWORD); jschSession.connect(SESSION_TIMEOUT); Channel sftp = jschSession.openChannel("sftp"); //建立sftp文件傳輸管道 sftp.connect(CHANNEL_TIMEOUT); ChannelSftp channelSftp = (ChannelSftp) sftp; // 傳輸本地文件到遠(yuǎn)程主機(jī) channelSftp.put(localFile, remoteFile); channelSftp.exit(); } catch (JSchException | SftpException e) { e.printStackTrace(); } finally { if (jschSession != null) { jschSession.disconnect(); } } System.out.println("文件傳輸完成!"); } }
3. JSch異常處理
在文件上傳的過程中,我們可能會遇到下面的一些異常
3.1UnknownHostKey異常
需要將遠(yuǎn)程服務(wù)器IP地址添加到known_hosts
文件中。
$ ssh-keyscan -t rsa 1.2.3.4 >> ~/.ssh/known_hosts
3.2對于私鑰無效異常
有可能是遠(yuǎn)程服務(wù)器重新生成了私鑰,需要把私鑰分發(fā)復(fù)制到本地服務(wù)器。
ssh-copy-id -i ~/.ssh/id_rsa.pub <被分發(fā)的服務(wù)器ip>
3.3對于Auth fail異常
請確保提供的登錄密碼時正確的
com.jcraft.jsch.JSchException: Auth fail at com.jcraft.jsch.Session.connect(Session.java:519) at com.zimug.io.howto.SFTPFileTransfer.main(SFTPFileTransfer.java:34)
作者:字母哥博客
以上就是如何在java中使用SFTP協(xié)議安全的傳輸文件的詳細(xì)內(nèi)容,更多關(guān)于Java 傳輸文件的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Java 基于UDP協(xié)議實(shí)現(xiàn)消息發(fā)送
這篇文章主要介紹了Java 基于UDP協(xié)議實(shí)現(xiàn)消息發(fā)送,幫助大家更好的理解和學(xué)習(xí)Java網(wǎng)絡(luò)編程,感興趣的朋友可以了解下2020-11-11Spring Cloud Config RSA簡介及使用RSA加密配置文件的方法
Spring Cloud 為開發(fā)人員提供了一系列的工具來快速構(gòu)建分布式系統(tǒng)的通用模型 。本文重點(diǎn)給大家介紹Spring Cloud Config RSA簡介及使用RSA加密配置文件的方法,感興趣的朋友跟隨腳步之家小編一起學(xué)習(xí)吧2018-05-05MyBatis-Plus標(biāo)簽@TableField之fill自動填充方式
這篇文章主要介紹了MyBatis-Plus標(biāo)簽@TableField之fill自動填充方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06RocketMQ消息生產(chǎn)者是如何選擇Broker示例詳解
這篇文章主要為大家介紹了RocketMQ消息生產(chǎn)者是如何選擇Broker示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11java實(shí)現(xiàn)圖片水平和垂直翻轉(zhuǎn)效果
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)圖片水平和垂直翻轉(zhuǎn)效果,圖片旋轉(zhuǎn)的靈活運(yùn)用,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01Java實(shí)現(xiàn)圖片上傳至FastDFS入門教程
這篇文章主要介紹了Java實(shí)現(xiàn)圖片上傳至FastDFS入門教程,通過前端ajax提交圖片到后端,java處理服務(wù)器文件上傳至FastDFS文件服務(wù)器系統(tǒng),以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07