2013-12-10 22 views
14

私のプロジェクトでは、アンドロイドデバイスから取得したイメージをサーバーサイトに送信しなければなりません。私は、デバイスサイト上のメソッドを呼び出すとき残念ながら、私はこのエラー満たす:レトロフィットを使用してサーバーにファイルをアップロードする

@Multipart 
@POST("/monument/photo/upload") 
void addMonumentPhoto(@Part("MonumentID") int monumentId, 
         @Part("name") String name, 
         @Part("subscript") String subscript, 
         @Part("photo") TypedFile photo, 
         Callback<Photo> callback); 

メソッドの宣言です

DEBUG/Retrofit(4429): java.lang.RuntimeException: 
    Unable to write multipart request. 
at retrofit.mime.MultipartTypedOutput.buildPart(MultipartTypedOutput.java:86) 
at retrofit.mime.MultipartTypedOutput.addPart(MultipartTypedOutput.java:49) 
at retrofit.RequestBuilder.setArguments(RequestBuilder.java:211) 
at retrofit.RestAdapter$RestHandler.invokeRequest(RestAdapter.java:264) 
at retrofit.RestAdapter$RestHandler.access$500(RestAdapter.java:197) 
at retrofit.RestAdapter$RestHandler$1.obtainResponse(RestAdapter.java:243) 
at retrofit.CallbackRunnable.run(CallbackRunnable.java:38) 
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076) 
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569) 
at retrofit.Platform$Android$2$1.run(Platform.java:134) 
at java.lang.Thread.run(Thread.java:856) 

Caused by: java.io.FileNotFoundException: /external/images/media/1270: 
    open failed: ENOENT (No such file or directory) 
at libcore.io.IoBridge.open(IoBridge.java:416) 
at java.io.FileInputStream.<init>(FileInputStream.java:78) 
at retrofit.mime.TypedFile.writeTo(TypedFile.java:74) 
at retrofit.mime.MultipartTypedOutput.buildPart(MultipartTypedOutput.java:83) 
... 10 more 

Caused by: libcore.io.ErrnoException: 
    open failed: ENOENT (No such file or directory) 
at libcore.io.Posix.open(Native Method) 
at libcore.io.BlockGuardOs.open(BlockGuardOs.java:110) 
at libcore.io.IoBridge.open(IoBridge.java:400) 
... 13 more 

を...そしてそれは私がそれを呼び出す方法です

photo = new File(selectedImageUri.getPath()); 
typedFile = new TypedFile("application/octet-stream", photo); 
MonumentsUtil.getApi().addMonumentPhoto(monument.getIdZabytek(), 
     "podpis", 
     "Main photo", 
     typedFile, 
     new Callback<Photo>() { 
    @Override 
    public void success(Photo aPhoto, Response response) { 
    } 

    @Override 
    public void failure(RetrofitError retrofitError) { 
     Log.e(TAG, retrofitError.getMessage()); 
    } 
}); 

サーバーのサイトでは、私はそのような方法を持っています:

@RequestMapping(value="/monument/photo/upload", method=RequestMethod.POST) 
public @ResponseBody Photo requestMonumentPhotoAdd(
     @RequestParam("MonumentID") int monumentId, 
     @RequestParam("name") String name , 
     @RequestParam("subscript") String subscript, 
     @RequestParam("photo") org.springframework.web.multipart.MultipartFile file) { 

    Photo photo = new Photo(); 
    photo.setIdZabytek(monumentId); 
    photo.setUri(URL+ "/images/" + name); 
    photo.setPodpis(subscript); 
    photo = monumentsRepo.addPhoto(photo); 
    String filePath = "D:\\Projekty\\Images\\" + monumentId + ":" + photo.getIdZjecia(); 

    if (!file.isEmpty()) { 
     try { 
      byte[] bytes = file.getBytes(); 
      BufferedOutputStream stream = new BufferedOutputStream(
       new FileOutputStream(new File(filePath))); 
      stream.write(bytes); 
      stream.close(); 
      photo.setUri(filePath); 
      monumentsRepo.updatePhoto(photo); 
      return photo; 
     } catch (Exception e) { 
      return null; 
     } 
    } else { 
     return null; 
    } 
} 

プログラムが障害ブロックに入り、なぜかわからない。誰かが間違いを指摘し、何が間違っているのか説明できますか?私のコードで補正した後

EDIT

に私は私が修正することはできません、次のエラーを持っている:

java.net.ProtocolException: content-length promised 1431984 bytes, but received 0  
    com.squareup.okhttp.internal.http.RetryableOutputStream.close(RetryableOutputStream.java:52), 
    com.squareup.okhttp.internal.http.HttpEngine.readResponse(HttpEngine.java:629), 
    com.squareup.okhttp.internal.http.HttpURLConnectionImpl.execute(HttpURLConnectionImpl.java: 346), 
    com.squareup.okhttp.internal.http.HttpURLConnectionImpl.getResponse(HttpURLConnectionImpl.java:295), 
    com.squareup.okhttp.internal.http.HttpURLConnectionImpl.getResponseCode(HttpURLConnectionImpl.java:489), 
retrofit.client.UrlConnectionClient.readResponse(UrlConnectionClient.java:90), 
retrofit.client.UrlConnectionClient.execute(UrlConnectionClient.java:48), 
retrofit.RestAdapter$RestHandler.invokeRequest(RestAdapter.java:287), 
retrofit.RestAdapter$RestHandler.access$500(RestAdapter.java:197), 
retrofit.RestAdapter$RestHandler$1.obtainResponse(RestAdapter.java:243), 
retrofit.CallbackRunnable.run(CallbackRunnable.java:38), 
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1076), 
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:569), 
retrofit.Platform$Android$2$1.run(Platform.java:134), 
java.lang.Thread.run(Thread.java:856) 

とHTTPレスポンス

HTTP/1.1 400 Bad Request, 
Connection: close, 
Content-Length: 1068, 
Content-Type:  text/html;charset=utf-8, 
Date: Wed, 11 Dec 2013 16:45:39 GMT, 
OkHttp-Received-Millis: 1386780339873, 
OkHttp-Response-Source: NETWORK 400, 
OkHttp-Selected-Transport: http/1.1, 
OkHttp-Sent-Millis: 1386780339799, Server: Apache-Coyote/1.1 

私は、サーバーのことを考えますメソッドが間違って記述される可能性がありますが、わかりません。誰でも助けてくれますか?

+0

これは解決されましたか? – dannyroa

答えて

9

Uri#getPathは、ファイルシステム上のパスではなくUriのパスコンポーネントを返します。

コンテンツプロバイダに実際のイメージを照会する必要があります。このようなもの:https://stackoverflow.com/a/20186918/132047

+0

修正後、別のエラーが発生します。上記の投稿を編集して、サーバーのサイトにretrofitの新しいstackTraceとエンドポイントメソッドを追加しました。私が間違っていることは何ですか? –

+0

より多くの例外(原因部分)を含める必要があります。それはlibcoreの中で深いので、あなたはそれを修正することができないかもしれません。より良いHTTPクライアントのために、アプリケーションにOkHttp jar /依存関係をドロップします。 –

+0

jarが追加され、新しいstackTraceが上記に含まれています。なぜコードが機能しないのか誰でも説明できますか?レトロフィットのように見えるのは、ヘッダーのcontent-length部分を設定できなかったようです –

関連する問題