2011-11-22 33 views
12

我試圖通過Android手機中的HttpClient上傳一張照片到服務器,但有時候我得到這個錯誤,它不會總是發生。任何人都知道如何解決它?HttpPost由於「無法重複請求與一個不可重複的請求實體」而失敗

我的代碼,如:

HttpClient client =new DefaultHttpClient(); 
HttpPut httpPut = new HttpPut(uploadUrl);  
InputStream in =null; 
HttpResponse response =null; 
     try { 
      in = new FileInputStream(filepath); 
      BasicHttpEntity entity = new BasicHttpEntity(); 
      entity.setContent(in); 
      entity.setContentLength(new File(basepath+path).length()); 

      httpPut.setEntity(entity); 
      response = client.execute(httpPut); 
      System.out.println(response.getStatusLine()); 


      consume(response.getEntity()); 


     } 

.......

錯誤信息:

11-22 10:32:50.370: W/System.err(15224): org.apache.http.client.ClientProtocolException 
11-22 10:32:50.370: W/System.err(15224): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:557) 
11-22 10:32:50.370: W/System.err(15224): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487) 
11-22 10:32:50.370: W/System.err(15224): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465) 
11-22 10:32:50.370: W/System.err(15224): at com.hp.nimbus.android.skydrive.util.SkyDriveUtils_Rest.doUploadPhoto(SkyDriveUtils_Rest.java:203) 
11-22 10:32:50.380: W/System.err(15224): at com.hp.nimbus.android.skydrive.util.SkyDriveUtils_Rest.uploadPhoto(SkyDriveUtils_Rest.java:250) 
11-22 10:32:50.380: W/System.err(15224): at com.hp.nimbus.android.skydrive.FolderMonitorService$1.onEvent(FolderMonitorService.java:36) 
11-22 10:32:50.380: W/System.err(15224): at android.os.FileObserver$ObserverThread.onEvent(FileObserver.java:125) 
11-22 10:32:50.380: W/System.err(15224): at android.os.FileObserver$ObserverThread.observe(Native Method) 
11-22 10:32:50.380: W/System.err(15224): at android.os.FileObserver$ObserverThread.run(FileObserver.java:88) 
11-22 10:32:50.380: W/System.err(15224): Caused by: org.apache.http.client.NonRepeatableRequestException: Cannot retry request with a non-repeatable request entity 
11-22 10:32:50.380: W/System.err(15224): at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:419) 
11-22 10:32:50.380: W/System.err(15224): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:555) 
11-22 10:32:50.390: W/System.err(15224): ... 8 more 
+0

嗨,謝謝你的回覆。我之前試過FileEntity,問題是上傳服務器不支持FileEntity,我不得不使用FileInputStream。你提到最初的請求失敗了,它能夠知道這個失敗的原因嗎? – user1059217

+3

不支持'FileEntity'聽起來很奇怪。對於一個簡單的修復,試着將你的實體包裝在BufferedHttpEntity中 - 這將使其可重複,但通過更多的內存咀嚼這樣做。 – Jens

回答

6

這意味着初始請求失敗,因爲它是一個流它可以不重複。

如果您刪除FileInputStream而改爲使用FileEntity,我相信它會是可重複的。

您也不必設置長度。

2

可能有點晚回答這個問題,但對於登陸此頁面的人來說,例外的原因是BasicHttpEntity不允許重複請求。您將需要使用正確的HttpEntity實現。

對於這個問題的情況,它將是FileEntity,正如Matthew Flaschen在另一個答案中提到的,但對於大多數其他情況,可以使用StringEntity這允許可重複的請求。