誰かが助けてくれることを願っています、
jersey と ApacheConnector を使用しているクライアントのために、春の webmvc アプリにクライアントを作成しました。jsessionid を保持する必要があり、ジャージーの HttpUrlConnector でそれを行う方法がわかりません。また、セッションを追跡する必要がある前に、ファイル アップロード サービスがジャージの HttpUrlConnector と連動していたことにも言及しておく必要があります。
私のWebフロントエンドはファイルをアップロードできるので、春のwebmvcファイルアップロードサービスが機能することを知っています。完全を期すために、このように見えます。
@ResponseBody
private Image onSubmit(@ModelAttribute("uploadedFile") ImageUpload imageUpload) {
service.create(imageUpload);
return new Image();
}
クライアントの初期化コードは次のようになります。
clientConfig = new ClientConfig();
connector = new ApacheConnector(clientConfig);
clientConfig.connector(connector);
client = ClientBuilder.newBuilder().withConfig(clientConfig)
.register(MultiPartFeature.class)
.register(JacksonJsonProvider.class).build();
target = client.target(url);
jackson 2.x を使いたかったので、MultiPartFeature と JacksonJsonProvider を登録しました。
ファイルをアップロードするクライアント コードは次のようになります。
File file = new File(fileName);
FormDataMultiPart formDataMultiPart = new FormDataMultiPart();
FormDataBodyPart bodyPart = new FormDataBodyPart("file", file,
MediaType.APPLICATION_OCTET_STREAM_TYPE);
formDataMultiPart.bodyPart(bodyPart);
response = target
.path(path)
.request()
.post(Entity.entity(formDataMultiPart,
formDataMultiPart.getMediaType()), Response.class);
次のようなコードも試しました。
final FileDataBodyPart filePart = new FileDataBodyPart("file", new File(fileName));
final MultiPart multipart = new FormDataMultiPart()
.field("foo", "bar")
.bodyPart(filePart);
response = target
.path(path)
.request()
.post(Entity.entity(multipart,
multipart.getMediaType()), Response.class);
これはドキュメントに最も近いものです。
ファイルがアップロードされると、サーバーが応答します
org.apache.commons.fileupload.FileUploadException: the request was rejected because no multipart boundary was found
at org.apache.commons.fileupload.FileUploadBase$FileItemIteratorImpl.<init>(FileUploadBase.java:990)
at org.apache.commons.fileupload.FileUploadBase.getItemIterator(FileUploadBase.java:310)
at org.apache.commons.fileupload.FileUploadBase.parseRequest(FileUploadBase.java:334)
at org.apache.commons.fileupload.servlet.ServletFileUpload.parseRequest(ServletFileUpload.java:115)
at org.springframework.web.multipart.commons.CommonsMultipartResolver.parseRequest(CommonsMultipartResolver.java:156)
at org.springframework.web.multipart.commons.CommonsMultipartResolver.resolveMultipart(CommonsMultipartResolver.java:139)
at org.springframework.web.servlet.DispatcherServlet.checkMultipart(DispatcherServlet.java:1047)
at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:892)
at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:856)
at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:936)
at org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:838)
これはかなり一般的な問題のように思えますが、これは境界が設定されていないことを意味すると思います。そのため、クライアントでデバッグを有効にしました。
DEBUG: org.apache.http.headers - >> POST /api/content/image/upload HTTP/1.1
DEBUG: org.apache.http.headers - >> Content-Type: multipart/form-data
DEBUG: org.apache.http.headers - >> User-Agent: Jersey/2.3.1 (Apache HttpClient 4.3)
DEBUG: org.apache.http.headers - >> Transfer-Encoding: chunked
DEBUG: org.apache.http.headers - >> Host: localhost:8010
DEBUG: org.apache.http.headers - >> Connection: Keep-Alive
DEBUG: org.apache.http.headers - >> Cookie: JSESSIONID=2xl9hgb4zq031jpbrn07ylp10
DEBUG: org.apache.http.headers - >> Cookie2: $Version=1
DEBUG: org.apache.http.wire - >> "7d[\r][\n]"
DEBUG: org.apache.http.wire - >> "--Boundary_1_674530318_1380707961372[\r][\n]"
DEBUG: org.apache.http.wire - >> "Content-Type: application/octet-stream[\r][\n]"
DEBUG: org.apache.http.wire - >> "Content-Disposition: form-data; name="file"[\r][\n]"
DEBUG: org.apache.http.wire - >> "[\r][\n]"
DEBUG: org.apache.http.wire - >> "[\r][\n]"
DEBUG: org.apache.http.wire - >> "1061[\r][\n]"
DEBUG: org.apache.http.wire - >> "[0x89]PNG[\r][\n]"
DEBUG: org.apache.http.wire - >> "[0x1a][\n]"
DEBUG: org.apache.http.wire - >> "[0x0][0x0][0x0][\r]IHDR[0x0] -!!!! SNIP you don't want to see this !!!!
DEBUG: org.apache.http.wire - >> "[\r][\n]"
DEBUG: org.apache.http.wire - >> "2a[\r][\n]"
DEBUG: org.apache.http.wire - >> "[\r][\n]"
DEBUG: org.apache.http.wire - >> "--Boundary_1_674530318_1380707961372--[\r][\n]"
DEBUG: org.apache.http.wire - >> "[\r][\n]"
DEBUG: org.apache.http.wire - >> "0[\r][\n]"
DEBUG: org.apache.http.wire - >> "[\r][\n]"
DEBUG: org.apache.http.wire - << "HTTP/1.1 500 Server Error[\r][\n]"
DEBUG: org.apache.http.wire - << "Content-Type: text/html; charset=ISO-8859-1[\r][\n]"
DEBUG: org.apache.http.wire - << "Cache-Control: must-revalidate,no-cache,no-store[\r][\n]"
DEBUG: org.apache.http.wire - << "Content-Length: 13979[\r][\n]"
DEBUG: org.apache.http.wire - << "Server: Jetty(9.0.5.v20130815)[\r][\n]"
DEBUG: org.apache.http.wire - << "[\r][\n]"
DEBUG: org.apache.http.impl.conn.DefaultClientConnection - Receiving response: HTTP/1.1 500 Server Error
DEBUG: org.apache.http.headers - << HTTP/1.1 500 Server Error
DEBUG: org.apache.http.headers - << Content-Type: text/html; charset=ISO-8859-1
DEBUG: org.apache.http.headers - << Cache-Control: must-revalidate,no-cache,no-store
DEBUG: org.apache.http.headers - << Content-Length: 13979
DEBUG: org.apache.http.headers - << Server: Jetty(9.0.5.v20130815)
DEBUG: org.apache.http.impl.client.DefaultHttpClient - Connection can be kept alive indefinitely
DEBUG: ws.webraw.jsonrest.JsonRestClient - reponse code : 500
--Boundary エントリが表示されないことを期待していました。ApacheConnector を使用しているときに、エンティティのエンコーディングに何か問題があったとしか思えません。
どんな助けでも大歓迎です!