Проблема с классом FTPClient в Java - PullRequest
8 голосов
/ 03 февраля 2009

Я использую 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, я что-то не так делаю?

Ответы [ 2 ]

14 голосов
/ 03 февраля 2009

Согласно API для FTPClient.retrieveFileStream(), метод возвращает null, когда не может открыть соединение для передачи данных, в этом случае вы должны проверить код ответа (например, getReplyCode(), getReplyString(), getReplyStrings()), чтобы понять, почему это не удалось. Кроме того, вы должны завершить передачу файлов, позвонив по номеру completePendingCommand() и проверив, что передача действительно была успешной.

2 голосов
/ 12 апреля 2012

Все работает нормально, когда я добавляю после команды "Получить":

        int response = client.getReply();
        if (response != FTPReply.CLOSING_DATA_CONNECTION){
            //TODO 
        }
...