Ошибка HttpPost из-за "Невозможно повторить запрос с неповторяющимся объектом запроса"

Я попытался загрузить фотографию на сервер HttpClient в Android-мобиле, но иногда я получаю эту ошибку, это не всегда. кто-нибудь знает, как его решить?

мой код вроде:

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

Ответ 1

Это означает, что исходный запрос не удался, и потому что он не может его повторить.

Если вы удалите FileInputStream и вместо этого используйте FileEntity, я считаю, что это будет повторяемо.

Вам также не нужно будет устанавливать длину.

Ответ 2

Возможно, вам будет немного поздно ответить на этот вопрос, но для людей, которые приземляются на этой странице, причина исключения - BasicHttpEntity не разрешает повторяющиеся запросы. Вам нужно будет использовать правильную реализацию HttpEntity.

В случае этого вопроса он будет FileEntity, как упоминал Матфей Флашен в другом ответе, но для большинства других случаев StringEntity, который позволяет выполнять повторяющиеся запросы.