[ https://issues.apache.org/jira/browse/CXF-8709?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17545171#comment-17545171 ]
Andriy Redko commented on CXF-8709: ----------------------------------- Hey [~minf...@apache.org] , do you mind please to share the jersey part (I assume the caller one)? It is unclear how you are trying to invoke this HTTP endpoint. > cxf-wadl2java-plugin: Consume "multipart/form-data" triggers 415 Unsupported > Media Type > --------------------------------------------------------------------------------------- > > Key: CXF-8709 > URL: https://issues.apache.org/jira/browse/CXF-8709 > Project: CXF > Issue Type: Bug > Components: JAX-RS > Affects Versions: 3.5.2 > Reporter: Graham Leggett > Priority: Major > > When an attempt is made to use the cxf-wadl2java-plugin against the wadl > below, the generated method is never matched by jersey, which always returns > "415 Unsupported Media Type". > {code} > <method name="POST" id="postArchivePaymentNote"> > <doc>Post an archive document to a paymentnote.</doc> > <request> > <representation mediaType="multipart/form-data"> > <doc>Uploaded files.</doc> > </representation> > <param name="Expect" style="header" type="xsd:string"> > <doc>Expect header requesting permission to upload as > described in https://datatracker.ietf.org/doc/html/rfc7231#section-5.1.1</doc> > </param> > <param name="Authorization" style="header" type="xsd:string"> > <doc>Authorization header containing username as described in > https://www.ietf.org/rfc/rfc2617.txt (Basic Authentication)</doc> > </param> > <param name="Accept" style="header" type="xsd:string"> > <doc>Accept header containing the requested variant as > described in https://www.ietf.org/rfc/rfc2616.txt</doc> > </param> > <param name="Origin" style="header" type="xsd:string"> > <doc>Origin header containing the CORS origin URL as > described in https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS</doc> > </param> > </request> > <response status="200"> > <representation mediaType="application/xml" > element="signatureservice:signatureservice"> > <doc>Return the signatureservice:signatureservice element on > success</doc> > </representation> > <representation mediaType="application/json" > element="signatureservice:signatureservice"> > <doc>Return the signatureservice:signatureservice element on > success</doc> > </representation> > <representation mediaType="text/plain"> > <doc>Return plain text result on success</doc> > </representation> > <doc>Browse a specific result.</doc> > </response> > <response status="400"> > <representation mediaType="application/xml" > element="signatureservice:signatureservice" /> > <representation mediaType="application/json" > element="signatureservice:signatureservice" /> > <representation mediaType="text/plain"/> > <doc>Invalid input strings, error message returned in "error" > property</doc> > </response> > <response status="403"> > <representation mediaType="application/xml" > element="signatureservice:signatureservice" /> > <representation mediaType="application/json" > element="signatureservice:signatureservice" /> > <representation mediaType="text/plain"/> > <doc>If forbidden, 403</doc> > </response> > <response status="404"> > <representation mediaType="application/xml" > element="signatureservice:signatureservice" /> > <representation mediaType="application/json" > element="signatureservice:signatureservice" /> > <representation mediaType="text/plain"/> > <doc>Result not found</doc> > </response> > </method> > {code} > The following interface is generated: > {code} > @POST > @Consumes("multipart/form-data") > @Produces({"application/xml", "application/json", "text/plain" }) > @Path("/paymentnote/{paymentnote}") > void postArchivePaymentNote(@PathParam("paymentnote") String paymentnote, > @HeaderParam("Expect") String expect, @HeaderParam("Authorization") String > authorization, @HeaderParam("Accept") String accept, > @HeaderParam("Origin") String origin, MultipartBody body, > @Suspended AsyncResponse async); > {code} > Removing async makes no difference, a MultipartBody body on it's own still > does not match. > One of the side effects of the generated interface is that it seems the body > is read into RAM/disk cache before being passed for processing, which is a > DoS vector. > Has multipart support ever been shown to work with cxf-wadl2java-plugin? -- This message was sent by Atlassian Jira (v8.20.7#820007)