2009-02-03 5 views
8

में FTP क्लाइंट क्लास के साथ समस्या मैं org.apache.commons.net.ftp.FTP क्लाइंट का उपयोग कर रहा हूं और व्यवहार देख रहा हूं, ठीक है ... परेशान।जावा

नीचे दी गई विधि एक FTPFile सूची के माध्यम से जाने का इरादा रखती है, उन्हें पढ़ें और फिर सामग्री के साथ कुछ करें। यह सब काम कर रहा है। क्या

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 वस्तु निम्नलिखित करता है ...? मैं एफ़टीपी क्लाइंट के लिए नया हूं, क्या मैं इसके साथ कुछ गलत कर रहा हूं?

+0

आप अपनी पोस्ट को संपादित कर सकते हैं तो बजाय अपने सूची आइटम के लिए कोड दृश्य का उपयोग कर आप के बजाय सूची आइटम के लिए प्रदान की शॉर्टकोड का उपयोग? इसे और अधिक पठनीय बनाता है :) – Kezzer

उत्तर

14

FTPClient.retrieveFileStream() के लिए एपीआई के अनुसार, विधि रिटर्न null जब यह डेटा कनेक्शन, जिस स्थिति में आप जबाब कोड (जैसे getReplyCode(), getReplyString(), getReplyStrings()) को देखने के लिए क्यों यह असफल जाँच करनी चाहिए नहीं खोल सकता। साथ ही, आप completePendingCommand() पर कॉल करके फ़ाइल स्थानांतरण को अंतिम रूप देने और मानते हैं कि स्थानांतरण वास्तव में सफल था।

+2

पूर्णपेंडिंग कॉमांड() !!!!! आप एक सज्जन और विद्वान हैं मैं उत्तर कोड (पिछली विधि में जहां मैं सभी कनेक्शन जंक करता हूं) की जांच कर रहा था और यह सब ठीक काम कर रहा था। मैंने दस्तावेज को अनदेखा किया जो पूर्णपेंडिंग कमांड के महत्व को निर्दिष्ट करता है। बहुत बहुत धन्यवाद। –

+0

इस जवाब के लिए धन्यवाद जैच स्क्रिप्वेना! लंबे समय से इस मुद्दे के साथ अटक गया था :) – krishnang

2

ठीक काम करता है "प्राप्त करें" आदेश के बाद जब मैं जोड़ें:

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