2

誰かが助けてくれることを願っています、

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 を使用しているときに、エンティティのエンコーディングに何か問題があったとしか思えません。

どんな助けでも大歓迎です!

4

2 に答える 2

2

これは、Jersey コネクタのすべての実装における既知の問題です。関連するバグはJERSEY-2123です。この問題を修正するためのリファクタリングは、JERSEY-2341で追跡されています。

現在推奨されている回避策は、ヘッダーに必要な値をClientBuilder使用java.net.HttpUrlConnectionして正しく追加するデフォルトの実装を単純に使用することです。boundaryContent-Type

于 2014-01-31T03:11:41.483 に答える