8

我正在使用 org.apache.commons.net.ftp.FTPClient 并看到行为,嗯......令人困惑。

下面的方法打算通过一个 FTPFile 列表,读入它们,然后对内容做一些事情。这一切都在工作。(真正)不起作用的是 FTPClient 对象执行以下操作...

1) Properly retrieves and stores the FIRST file in the list  
2) List item evaluates to NULL for x number of successive iterations of the loop (x varies on successive attempts  
3) manages to retrieve exactly 1 more file in the list  
4) reports that it is null for exactly 1 more file in the list  
5) hangs indefinitely, reporting no further activity.

public static String mergeXMLFiles(List<FTPFile> files, String rootElementNodeName, FTPClient ftp){
        String ret = null;
        String fileAsString   = null; 
        //InputStream inStream;
        int c;

        if(files == null || rootElementNodeName == null)
            return null;
        try {
            System.out.println("GETTING " + files.size() + " files");
            for (FTPFile file : files) {
                fileAsString = "";
                InputStream inStream = ftp.retrieveFileStream(file.getName());

                if(inStream == null){
                    System.out.println("FtpUtil.mergeXMLFiles() couldn't initialize inStream for file:" + file.getName());

                    continue;//THIS IS THE PART THAT I SEE FOR files [1 - arbitrary number (usually around 20)] and then 1 more time for [x + 2] after [x + 1] passes successfully.
                }
                while((c = inStream.read()) != -1){

                    fileAsString += Character.valueOf((char)c);
                }
                inStream.close();


                System.out.println("FILE:" + file.getName() + "\n" + fileAsString);
            }


        } catch (Exception e) {
            System.out.println("FtpUtil.mergeXMLFiles() failed:" + e);
        }
        return ret;
    }

有人见过这样的吗?我是 FTPClient 的新手,我做错了什么吗?

4

2 回答 2

14

根据 的 API FTPClient.retrieveFileStream(),该方法null在无法打开数据连接时返回,这种情况下您应该检查回复代码(例如getReplyCode()getReplyString()getReplyStrings())以了解其失败的原因。此外,您应该通过调用completePendingCommand()并验证传输确实成功来完成文件传输。

于 2009-02-03T16:12:25.967 回答
2

当我在“检索”命令之后添加时它工作正常:

        int response = client.getReply();
        if (response != FTPReply.CLOSING_DATA_CONNECTION){
            //TODO 
        }
于 2012-04-12T19:43:00.393 回答