2013-04-08 133 views
0

因此,我對此很新,而且我的應用程序不斷崩潰。我在這裏發現了這個代碼,無法讓它爲我的生活工作。我想要做的只是下載選定的文件,並且當我不在作業文件夾的子目錄中時它可以工作。我從MySQL數據庫下載作業文件夾名稱,並且工作正常。每個職業都有照片,文檔,雜項等子......說我有工作4131 ..和4131裏面有以下..異步任務致命異常 - 線程正在退出,未捕獲的異常

4131/cdgjkg.png 4131 /雜項 4131 /照片

和photots裏面還有另一個png。 (4131 /圖片/ dioghg.png)。問題是,如果我下載了基於4131方法的png wthin,它就起作用了。沒有錯誤。如果我進入Photots目錄並嘗試下載該文件,我會收到大量異步錯誤。以下是代碼。如果您需要了解更多信息,請告訴我們。

new LoadAllJobs().execute(); 

    ListView lv = getListView(); 

    lv.setOnItemClickListener(new OnItemClickListener() { 
     @Override 
     public void onItemClick(AdapterView<?> parent, View view, int position, long id) { 
      String file = ((TextView)view).getText().toString(); 
      String current_dir = dir + "/" + file; 
      if(file.contains(".")){ 
       //download the file or view it 
       try { 
        Log.d("Downloading ", file); 
        new FTPDownload().execute(file); // <-----This is where I start the task to enter the FTPDownload, never to be seen again :(
        Log.d("Success ", current_dir); 
       } 
       catch (Exception e) { 
        e.printStackTrace(); 
       } 

這是一個塊,我只是檢索列表並下載文件,只有當它包含'。' ('。'字符不允許在服務器上的文件夾名稱中,所以這是個很快的做法)。

FTPDownload類

class FTPDownload extends AsyncTask<String, Integer, String> { 
//public FTPClient client; 

@Override 
protected String doInBackground(String... filename) { 
    try { 
     System.out.println("Filename->: " + filename[0]); 
     GetFileFTP("/" + filename[0], Environment.getExternalStorageDirectory() + "/Download/", filename[0]); 
    } 
    finally 
    { 
     //e.printStackTrace(); 
     Log.v("DONE: ", "All done!"); 
    } 
    System.out.println("I HATE YOU."); // <----- NEVER REACHES THIS LINE WHEN TRYING TO DOWNLOAD IN A SUBFOLDER 
    return null; 
} 



    public void GetFileFTP(String srcFileSpec, String destpath, String destname) { 
    FTPClient client = new FTPClient(); 
    Log.v("pathSpec: ", destpath); 

    try { 
     client.connect("xxxxxx"); 
     client.login("xxxxxx", "xxxxxx"); 

     client.enterLocalPassiveMode(); 
     client.setFileType(org.apache.commons.net.ftp.FTP.BINARY_FILE_TYPE); 

     InputStream input = client.retrieveFileStream(srcFileSpec); 
     if(input != null) Log.v("GetFileFTP: ", "INPUT STREAM OPENED SUCCESSFULLY!"); 
     Log.v("File InputStream: ", srcFileSpec); 

     File output_file = new File(destpath + destname); 
     Log.v("OUTPUTFILE: ", destpath + destname); 

     inputstreamcopy(input, output_file); 

     /*try { 
      //Log.e("Closing connection: ", client.toString()); 
      client.logout(); 
      client.disconnect(); 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     }*/ 
    } 
    catch (IOException e) { 
     Log.e("FTP", "Error Getting File"); 
     e.printStackTrace(); 
    } 
} 

    public static void inputstreamcopy(InputStream source, File destination){ 
     try { 
      org.apache.commons.io.FileUtils.copyInputStreamToFile(source, destination); 
     } catch (IOException e) { 
      // TODO Auto-generated catch block 
      e.printStackTrace(); 
     } 
    } 
} 

控制檯輸出

04-08 15:10:05.010: D/Downloading(29309): login.php 
04-08 15:10:05.010: D/Success(29309): 4131/Miscellaneous/login.php 
04-08 15:10:05.010: I/System.out(29309): Filename->: login.php 
04-08 15:10:05.020: V/pathSpec:(29309): /storage/emulated/0/Download/ 
04-08 15:10:06.010: V/File InputStream:(29309): /login.php 
04-08 15:10:06.020: V/OUTPUTFILE:(29309): /storage/emulated/0/Download/login.php 
04-08 15:10:06.030: V/DONE:(29309): All done! 
04-08 15:10:06.030: W/dalvikvm(29309): threadid=11: thread exiting with uncaught exception (group=0x418f5930) 
04-08 15:10:06.040: E/AndroidRuntime(29309): FATAL EXCEPTION: AsyncTask #1 
04-08 15:10:06.040: E/AndroidRuntime(29309): java.lang.RuntimeException: An error occured while executing doInBackground() 
04-08 15:10:06.040: E/AndroidRuntime(29309): at android.os.AsyncTask$3.done(AsyncTask.java:299) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at java.util.concurrent.FutureTask.finishCompletion(FutureTask.java:352) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at java.util.concurrent.FutureTask.setException(FutureTask.java:219) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at java.util.concurrent.FutureTask.run(FutureTask.java:239) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:230) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at java.lang.Thread.run(Thread.java:856) 
04-08 15:10:06.040: E/AndroidRuntime(29309): Caused by: java.lang.NullPointerException 
04-08 15:10:06.040: E/AndroidRuntime(29309): at org.apache.commons.io.IOUtils.copyLarge(IOUtils.java:1792) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at org.apache.commons.io.IOUtils.copyLarge(IOUtils.java:1769) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at org.apache.commons.io.IOUtils.copy(IOUtils.java:1744) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at org.apache.commons.io.FileUtils.copyInputStreamToFile(FileUtils.java:1512) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at com.example.tdsi.FTPDownload.inputstreamcopy(FTPDownload.java:70) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at com.example.tdsi.FTPDownload.GetFileFTP(FTPDownload.java:51) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at com.example.tdsi.FTPDownload.doInBackground(FTPDownload.java:21) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at com.example.tdsi.FTPDownload.doInBackground(FTPDownload.java:1) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at android.os.AsyncTask$2.call(AsyncTask.java:287) 
04-08 15:10:06.040: E/AndroidRuntime(29309): at java.util.concurrent.FutureTask.run(FutureTask.java:234) 
04-08 15:10:06.040: E/AndroidRuntime(29309): ... 4 more 
+0

什麼是第70行?有些東西是'空'的。可能'文件名' – codeMagic 2013-04-08 23:21:08

回答

2

這是您的罪魁禍首:

04-08 15:10:06.040: E/AndroidRuntime(29309): Caused by: java.lang.NullPointerException 
[...] 
org.apache.commons.io.FileUtils.copyInputStreamToFile(FileUtils.java:1512) 

你傳入nullinputstreamcopy(),這導致NPE。

+0

我已經在inputstreamcopy()被調用之前打印這兩個值並且它們不爲空... – JTester 2013-04-09 00:39:14

+0

我在零件中添加了這個: Log.v(「準備創建IS:」,「試圖創建InputStream輸入「); InputStream input = client.retrieveFileStream(srcFileSpec); Log.v(「IS Created:」,input.toString()); 當我嘗試從子文件夾下載時,它甚至沒有把它創建到IS創建(第3行),它只是崩潰。 – JTester 2013-04-09 00:48:19

相關問題