通过java读取远程nfs服务器文件

1.什么是NFS

NFSNetwork File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源。在NFS的应用中,本地NFS的客户端应用可以透明地读写位于远端NFS服务器上的文件,就像访问本地文件一样。

2.NFS适合哪种操作系统

NFS是运行在应用层的协议。随着NFS多年的发展和改进,NFS既可以用于局域网也可以用于广域网,且与操作系统和硬件无关,可以在不同的计算机或系统上运行。

3.一个简单的NFS使用(局域网使用)

服务端:安装软件

客户端:http://jingyan.baidu.com/article/0a52e3f4dc3f4abf63ed7259.html

注意:win7非企业版本没有nfs功能选项

4.编写java代码读出远程客户端的文件内容

使用的包有 jftp.jar  

这是包下载路径   http://download.csdn.net/download/kunfd/9935005


import java.io.File;
import java.io.FileFilter;
import java.io.IOException;

import com.sun.nfs.XFileExtensionAccessor;
import com.sun.xfile.*;
import net.sf.jftp.system.logging.Log;

import java.io.*;
import java.util.ArrayList;
import java.util.List;

/**
 * Created by fd on 2017/8/14.
 */
public class NFS {
    String url;
    XFile xfile;
    public void NFSconnection(String ip,String dir)
    {
        url = "nfs://" + ip + "/" + dir;//创建连接
         xfile = new XFile(url);
        //调用exists()判断是否连接成功
        if (xfile.exists()) {
            System.out.println("URL is OK!");
        } else {
            System.out.println("URL is Bad!");
            return;
        }

    }
    public void coming(String pathname) throws IOException {
        String path[] = pathname.split("/");//切割,如果服务器是unix系统,更改为"\"
        String[] fileList = new String[1024];//设置接收目录扫描的长度,暂时设置为1024
        fileList = xfile.list();//缺少这一句的话,会出现找不到文件的错误
        XFile temp;
        XFileInputStream in = null;
        for(String splittext:path){
            url = url+"/"+splittext;
            temp = new XFile(url);
              in = new XFileInputStream(temp);
            fileList = temp.list();
        }
        BufferedReader reader = new BufferedReader(new InputStreamReader(in,"GBK"));
        String line;
        while ((line = reader.readLine()) != null) {
            System.out.println(line);
        }
    }

    public static void main(String[] args) throws IOException {
        String ip ="172.19.152.32";
        String dir = "nfs";
        NFS nfs = new NFS();
        nfs.NFSconnection(ip,dir);
        nfs.coming("com/gdin/edu/test1.txt");
    }
}




5.附加

①我测试的时候服务端是在Windows系统,连接的时候无需登录(这样不安全,不过可以在服务端设置连接用户的权限,具体的自己去尝试)

Linux上的还没有测试,按道理应该也是可以的,而且如果换到Linux系统,有些东西需要更改,比如文件路径等

③这些测试都是在局域网上测试的

  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
Java可以使用URLConnection类或者Apache HttpClient库来读取远程服务器文件列表。 1. 使用URLConnection类: 首先,创建一个URL对象,指定要访问的远程服务器地址。然后,使用URL对象的openConnection()方法打开一个连接,并转换为HttpURLConnection对象。接着,设置HTTP请求的方法(GET、POST等)、超时时间等属性,并连接到远程服务器。通过getInputStream()方法获取远程服务器的响应数据流,并使用BufferedReader逐行读取文件列表。 以下是示例代码: ``` import java.io.BufferedReader; import java.io.InputStreamReader; import java.net.HttpURLConnection; import java.net.URL; public class RemoteFileReader { public static void main(String[] args) { try { URL url = new URL("https://example.com/filelist"); // 替换为实际的远程服务器地址 HttpURLConnection connection = (HttpURLConnection)url.openConnection(); connection.setRequestMethod("GET"); connection.setConnectTimeout(5000); // 设置连接超时时间为5秒 connection.connect(); BufferedReader reader = new BufferedReader(new InputStreamReader(connection.getInputStream())); String line; while ((line = reader.readLine()) != null) { System.out.println(line); // 输出远程服务器文件列表 } reader.close(); connection.disconnect(); } catch (Exception e) { e.printStackTrace(); } } } ``` 2. 使用Apache HttpClient库: 首先,引入Apache HttpClient库的相关依赖。然后,创建一个HttpClient对象,并使用HttpGet请求指定的远程服务器地址。通过调用execute()方法发送请求并获取响应。使用EntityUtils类将响应的实体转换为字符串,并解析获取文件列表信息。 以下是示例代码: ``` import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; public class RemoteFileReader { public static void main(String[] args) { try { HttpClient httpClient = HttpClients.createDefault(); HttpGet httpGet = new HttpGet("https://example.com/filelist"); // 替换为实际的远程服务器地址 HttpResponse response = httpClient.execute(httpGet); HttpEntity entity = response.getEntity(); String filelist = EntityUtils.toString(entity); // 获取文件列表字符串 System.out.println(filelist); // 输出远程服务器文件列表 httpClient.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 无论是使用URLConnection类还是Apache HttpClient库,需要替换示例代码中的远程服务器地址为实际的地址。在实际应用中,可能需要根据远程服务器的访问授权、协议、端口等设置相关参数。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值