使用Apache 的 FTP Client擷取FTP伺服器上的檔案清單FTP response 421 received.Server closed connection問題的解決
@for & ever 2009-12-09
使用Apache 的 FTP Client (JAVA開源包commons-net-2.0包)擷取FTP伺服器上的檔案清單,寫一個遞迴迴圈的list()方法.
當 FTP 伺服器上的檔案數目過多時,運行程式
FTPFile[] fs = ftp.listFiles(pathName);
並且通過
for (FTPFile f : fs) {
// TODO something
}
擷取目錄列表,會出現如下的異常:
PORT 192,168,0,17,73,49
421 Timeout.
org.apache.commons.net.ftp.FTPConnectionClosedException: FTP response 421 received. Server closed connection.
at org.apache.commons.net.ftp.FTP.__getReply(FTP.java:346)
at org.apache.commons.net.ftp.FTP.sendCommand(FTP.java:490)
at org.apache.commons.net.ftp.FTP.sendCommand(FTP.java:534)
at org.apache.commons.net.ftp.FTP.port(FTP.java:862)
at org.apache.commons.net.ftp.FTPClient._openDataConnection_(FTPClient.java:463)
at org.apache.commons.net.ftp.FTPClient.initiateListParsing(FTPClient.java:2296)
at org.apache.commons.net.ftp.FTPClient.initiateListParsing(FTPClient.java:2269)
at org.apache.commons.net.ftp.FTPClient.listFiles(FTPClient.java:2047)
因此,為了防止出現這個異常,只好採用擷取RawListing的方式,然後通過正則來解析 String 得到目錄列表和目錄包含的檔案詳細資料。
=====================================
在使用了下面的部分就會經常出現問題
public static void list(FTPClient ftp, String pathName, String fileName) throws IOException {
System.out.println("-----> 進入目錄: " + pathName);
if (i % 20 == 0) {
//ftp.changeWorkingDirectory(pathName);
try {
writeFile(s, fileName);
s = "";
} catch (Exception e) {
e.printStackTrace();
}
try {
Random r = new Random();
int n = r.nextInt(10);
Thread.sleep(n * 1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
i++;
// XXXXXXXXX DO something
}
@forandever 2009-12-09