[英]Apache Commons FTPClient Not Retrieving All Bytes From Source File
我有一个相当基本的3.8.0 FTPClient用例:
FTPClient ftpClient = new FTPClient()
ftpClient.connect(hostName, hostPort)
if(FTPReply.isPositiveCompletion(ftpClient.getReplyCode())) {
ftpClient.setFileType(FTP.BINARY_FILE_TYPE)
ftpClient.login(userName, password)
FileOutputStream fos = new FileOutputStream("localFile.txt")
ftpClient.retrieve("remoteFile.zip", fos)
}
我遇到的问题是生成的本地文件总是比远程源文件小 ~1400 字节:
source file size: 134,914,722
dest file size: 134,913,316
这似乎不是服务器问题,因为标准 linux ftp 命令检索整个文件。
它似乎也与OutputStream
无关,因为当我将文件内容拉入 memory 时,我遇到了同样的问题:
//still too small
Byte[] fileContents = ftpClient.retrieveFileStream("remoteFile.zip").readAllBytes()
什么会导致 apache commons FTPClient 允许连接和文件下载,但不能从源文件中彻底检索所有字节?
预先感谢您的考虑和回复。
问题是setFileType
的顺序; 它应该在login
之后而不是之前。
ftpClient.connect(...
ftpClient.login(...
ftpClient.setFileType(FTP.BINARY_FILE_TYPE)
文件变小可能是由于原始 zip 文件的字符集解释。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.