您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)java中如何使用SFTP協(xié)議傳輸文件,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
SSH 是較可靠,專(zhuān)為遠(yuǎn)程登錄會(huì)話和其他網(wǎng)絡(luò)服務(wù)提供安全性的協(xié)議。比如:我們購(gòu)買(mǎi)的云服務(wù)器登陸的時(shí)候使用的協(xié)議都是ssh。
一般來(lái)說(shuō),SFTP和FTP服務(wù)都是使用相應(yīng)的客戶端軟件來(lái)提供服務(wù)。如果你希望在java代碼中使用SFTP協(xié)議進(jìn)行安全的文件傳輸,那么這篇文章非常適合你。
1. 導(dǎo)入JSch 依賴(lài)包
在maven項(xiàng)目pom.xml中導(dǎo)入如下的坐標(biāo),我們使用JSch,JSch將SFTP協(xié)議封裝為對(duì)應(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
方法用來(lái)將文件從本地系統(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);
2.3.使用公鑰和私鑰進(jìn)行認(rèn)證
如果讀者不能理解公鑰和私鑰的用法及含義,需要先自行補(bǔ)充一下SSH知識(shí)。
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超時(shí)時(shí)間 private static final int CHANNEL_TIMEOUT = 5000; //管道流超時(shí)時(shí)間 public static void main(String[] args) { String localFile = "/home/zimug/local/random.txt"; //本地文件路徑 String remoteFile = "/home/zimug/remote/targetfile.txt"; //上傳到遠(yuǎn)程的文件路徑,要保證登錄用戶有寫(xiě)權(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); // 通過(guò)ssh私鑰的方式登錄認(rèn)證 // jsch.addIdentity("/home/zimug/.ssh/id_rsa"); // 通過(guò)密碼的方式登錄認(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異常處理
在文件上傳的過(guò)程中,我們可能會(huì)遇到下面的一些異常
3.1UnknownHostKey異常
需要將遠(yuǎn)程服務(wù)器IP地址添加到known_hosts
文件中。
$ ssh-keyscan -t rsa 1.2.3.4 >> ~/.ssh/known_hosts
3.2對(duì)于私鑰無(wú)效異常
有可能是遠(yuǎn)程服務(wù)器重新生成了私鑰,需要把私鑰分發(fā)復(fù)制到本地服務(wù)器。
ssh-copy-id -i ~/.ssh/id_rsa.pub <被分發(fā)的服務(wù)器ip>
3.3對(duì)于Auth fail異常
請(qǐng)確保提供的登錄密碼時(shí)正確的
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)
關(guān)于java中如何使用SFTP協(xié)議傳輸文件就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。