ftpClient.listFiles()获得文件数量为0

本文介绍了使用Serv-U搭建FTP服务器时遇到的下载问题及解决方案。通过对代码进行调试,发现服务器返回的文件信息与解析文件名的正则表达式不匹配,导致无法正确获取文件数量。最终通过移除特定的服务器系统配置解决了该问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

为了方便文件的上传下载,搭建了一个ftp,用的是servu,文件的上传没什么问题,但下载有就问题啦,获得指定文件夹下面的文件,数量为零,在网上找了好久,没有找到答案。没办法自己下载源码,来研究一下。在调试代码中,本人ftp的系统是xp。所以在自己的代码到有这样一段代码


FTPClientConfig ftpConfig = new FTPClientConfig(FTPClientConfig.SYST_NT);
ftpConfig.setServerLanguageCode(FTP.DEFAULT_CONTROL_ENCODING);


这个可填可不填,是一个ftp的一个服务器系统配置,不填的话,连接时自己去判断。
如果你填了,就是有相应的一个文件 格式的判断、

String infotype="-rw-rw-rw- 1 user group 91573 Nov 11 14:57 info1444154439181.doc";
//这个是服务器返回对应文件夹下面的文件
String reg="(\\S+)\\s+(\\S+)\\s+(?:(<DIR>)|([0-9]+))\\s+(\\S.*)";
//这个是你配置服务器系统,下面解析对应文件名的一个正则表达式。
这明显的不匹配。

所以解决办法就是不去陪
FTPClientConfig ftpConfig = new FTPClientConfig(FTPClientConfig.SYST_NT);

连接时自己去判断,测试一下通过。
以下是Java实现FTP多线程下载文件的示例代码: ```java import org.apache.commons.net.ftp.FTP; import org.apache.commons.net.ftp.FTPClient; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStream; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; public class FTPMultiThreadDownload { private static final String FTP_SERVER = "ftp.example.com"; private static final int FTP_PORT = 21; private static final String FTP_USERNAME = "username"; private static final String FTP_PASSWORD = "password"; private static final String REMOTE_FILE_PATH = "/path/to/remote/file"; private static final String LOCAL_FILE_PATH = "/path/to/local/file"; public static void main(String[] args) { FTPClient ftpClient = new FTPClient(); try { ftpClient.connect(FTP_SERVER, FTP_PORT); ftpClient.login(FTP_USERNAME, FTP_PASSWORD); ftpClient.enterLocalPassiveMode(); ftpClient.setFileType(FTP.BINARY_FILE_TYPE); int threadCount = 5; // 设置线程数量 ExecutorService executorService = Executors.newFixedThreadPool(threadCount); long fileSize = ftpClient.listFiles(REMOTE_FILE_PATH)[0].getSize(); long partSize = fileSize / threadCount; for (int i = 0; i < threadCount; i++) { long startPos = i * partSize; long endPos = (i + 1) * partSize - 1; if (i == threadCount - 1) { endPos = fileSize - 1; } executorService.execute(new DownloadThread(ftpClient, REMOTE_FILE_PATH, LOCAL_FILE_PATH, startPos, endPos)); } executorService.shutdown(); } catch (IOException e) { e.printStackTrace(); } finally { try { if (ftpClient.isConnected()) { ftpClient.logout(); ftpClient.disconnect(); } } catch (IOException e) { e.printStackTrace(); } } } private static class DownloadThread implements Runnable { private FTPClient ftpClient; private String remoteFilePath; private String localFilePath; private long startPos; private long endPos; public DownloadThread(FTPClient ftpClient, String remoteFilePath, String localFilePath, long startPos, long endPos) { this.ftpClient = ftpClient; this.remoteFilePath = remoteFilePath; this.localFilePath = localFilePath; this.startPos = startPos; this.endPos = endPos; } @Override public void run() { OutputStream outputStream = null; try { outputStream = new FileOutputStream(localFilePath, true); ftpClient.setRestartOffset(startPos); ftpClient.retrieveFile(remoteFilePath, outputStream); } catch (IOException e) { e.printStackTrace(); } finally { try { if (outputStream != null) { outputStream.close(); } } catch (IOException e) { e.printStackTrace(); } } } } } ``` 请注意,上述代码使用了Apache Commons Net库来处理FTP操作。在代码中,我们首先建立与FTP服务器的连接,然后设置登录凭据和文件类型。接下来,我们确定要下载的文件的大小,并根据线程数量文件分成多个部分。然后,我们使用线程池来创建并执行多个下载线程,每个线程负责下载文件的一个部分。每个线程都会将其下载的部分写入本地文件。最后,我们关闭连接和线程池。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值