Java基于nfs-client包实现NFS协议连接linux服务器进行文件上传与下载操作源码

2023-02-17 00:00:00 java NFS

添加依赖

// 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
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。

相关文章