When i download file with following code it just write the file to destination on local but file size are all zero. Can anybody say Why this happen and how to fix it?
import org.apache.commons.net.ftp.FTPClient;
import org.apache.commons.net.ftp.FTPFile;
import java.io.FileOutputStream;
import java.io.IOException;
public class FtpDownload {
public static void main(String[] args) {
FTPClient client = new FTPClient();
FileOutputStream fos = null;
String filename = "config.zip";
try {
client.connect("ftpsrv");
client.login("user", "user");
for (FTPFile file : client.listFiles()) {
filename = "C:\\tmp\\user\\" + file.getName();
if (file.isFile()) {
fos = new FileOutputStream(filename);
client.retrieveFile(filename, fos);
System.out.println(file.getName());
} else if (file.isDirectory()) {
System.out.println("directory: " + file.getName());
}
}
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (fos != null) {
fos.close();
}
client.disconnect();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
try closing the stream on every iteration in the loop
Your code is not doing it correctly because you have a for loop that creates new stream every iteration but only close the last one
after searching in the Apache documentation i come to conclusion that BINARY_FILE_TYPE is not yet settled. i have add following code and everything is OK. thanks to all of you that did help.
You're using the local path variable to point to the remote file:
You want to point to the remote file, not the local destination, like this:
Also, make sure you close your
fos
stream after reading each file, rather than right at the end. You can useIOUtils.closeQuietly(fos);
for this if you get the commons.io library, which avoids the nested try-catch blocks.You should also use BINARY file type and BLOCK transfer mode for transferring zip files: