Java基于nfs-client包实现NFS协议连接linux服务器进行文件上传与下载操作源码
添加依赖
// https://mvnrepository.com/artifact/com.emc.ecs/nfs-client
compile group: 'com.emc.ecs', name: 'nfs-client', version: '1.0.3'
代码示例
package com.xl;
import com.emc.ecs.nfsclient.nfs.io.Nfs3File;
import com.emc.ecs.nfsclient.nfs.io.NfsFileInputStream;
import com.emc.ecs.nfsclient.nfs.io.NfsFileOutputStream;
import com.emc.ecs.nfsclient.nfs.nfs3.Nfs3;
import com.emc.ecs.nfsclient.rpc.CredentialUnix;
import java.io.*;
public class NfsTransferFile {
private static final String NFS_IP = "192.168.0.101";
private static final String NFS_DIR = "/data/nfs";
public static void main(String[] args) {
uploadFileToNfs();
//downLoadFileFromNfs();
}
//上传本地文件到Nfs服务器指定目录
public static void uploadFileToNfs() {
String localDir = "F:\\look\\look.txt";
InputStream inputStream = null;
OutputStream outputStream = null;
try {
//创建一个本地文件对象
File localFile = new File(localDir);
//获取本地文件的文件名,此名字用于在远程的Nfs服务器上指定目录创建同名文件
String localFileName = localFile.getName();
Nfs3 nfs3 = new Nfs3(NFS_IP, NFS_DIR, new CredentialUnix(0, 0, null), 3);
//创建远程服务器上Nfs文件对象
Nfs3File NfsFile = new Nfs3File(nfs3, "/" + localFileName);
//打开一个文件输入流
inputStream = new BufferedInputStream(new FileInputStream(localFile));
//打开一个远程Nfs文件输出流,将文件复制到的目的地
outputStream = new BufferedOutputStream(new NfsFileOutputStream(NfsFile));
//缓冲内存
byte[] buffer = new byte[1024];
while ((inputStream.read(buffer)) != -1) {
outputStream.write(buffer);
}
System.out.println("文件上传完成!");
} catch (Exception ex) {
ex.printStackTrace();
} finally {
try {
if (outputStream != null) {
outputStream.close();
}
if (inputStream != null) {
inputStream.close();
}
} catch (IOException ex) {
ex.printStackTrace();
}
}
}
//从Nfs服务器上下载指定的文件到本地目录
public static void downLoadFileFromNfs() {
String NfsFileDir = "/look.txt";
String localDir = "F:\\look\\";
InputStream inputStream = null;
OutputStream outputStream = null;
try {
Nfs3 nfs3 = new Nfs3(NFS_IP, NFS_DIR, new CredentialUnix(0, 0, null), 3);
//创建远程服务器上Nfs文件对象
Nfs3File nfsFile = new Nfs3File(nfs3, NfsFileDir);
String localFileName = localDir + nfsFile.getName();
//创建一个本地文件对象
File localFile = new File(localFileName);
//打开一个文件输入流
inputStream = new BufferedInputStream(new NfsFileInputStream(nfsFile));
//打开一个远程Nfs文件输出流,将文件复制到的目的地
outputStream = new BufferedOutputStream(new FileOutputStream(localFile));
//缓冲内存
byte[] buffer = new byte[1024];
while (inputStream.read(buffer) != -1) {
outputStream.write(buffer);
}
System.out.println("文件下载完成!");
} catch (IOException ex) {
ex.printStackTrace();
} finally {
try {
if (outputStream != null) {
outputStream.close();
}
if (inputStream != null) {
inputStream.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
原文作者:醉野丶
原文地址: https://blog.csdn.net/ZYQ_1004/article/details/104947117
本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
原文地址: https://blog.csdn.net/ZYQ_1004/article/details/104947117
本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
相关文章