【问题标题】:Jersey throws ParseException when uploading file in multipart/form-data requestJersey 在 multipart/form-data 请求中上传文件时抛出 ParseException
【发布时间】:2015-10-29 02:42:51
【问题描述】:

我正在尝试向我的 Jersey REST 服务发送一个 mp3 文件和一些元数据。为此,我尝试使用 multipart/form-data 内容类型,但是当我发送请求时,我总是得到 java.text.ParseException: Next event is not a Separator。整个回应:

{"restResponse":{
"responseCode":"INVALID_PARAMETER",
"i18nMessage":"Invalid Parameter: Next event is not a Separator",
"responseDescription":"The request contains an invalid parameter"}}

如果我从请求中删除 mp3 文件,它可以正常工作,所以我认为我的请求的构造方式存在问题。我正在使用 Paw,它会生成这样的请求:

POST /rest/myapi/recording/multipart HTTP/1.1
Accept: application/json
Accept-Language: en-US
Content-Type: multipart/form-data; boundary=EI6FArOacJKf5JCY5BAA2sbl2IAfN8ty
Cookie: JSESSIONID=a5f5cfa7329142158766a6182645; JSESSIONIDSSO=BAFA3371F6D14A179B0BA6216DD6C119
Host: localhost:8181
Connection: close
User-Agent: Paw/2.2.2 (Macintosh; OS X/10.10.5) GCDHTTPRequest
Content-Length: 44504

--EI6FArOacJKf5JCY5BAA2sbl2IAfN8ty
Content-Disposition: form-data; name="queue"

qMultipart
--EI6FArOacJKf5JCY5BAA2sbl2IAfN8ty
Content-Disposition: form-data; name="datetime"

20151029-021807
--EI6FArOacJKf5JCY5BAA2sbl2IAfN8ty
Content-Disposition: form-data; name="recording"; filename="test4_multiform.mp3"
Content-Type: audio/mpeg

ID3ETT2test4_multiformCOMengiTunPGAP0TENiTunes 12.3.0.44COMhengiTunNORM 00000152 00000152 000013BE 000013BE 0000023E 0000023E 00003F10 00003F10 000002A7 000002A7COMengiTunSMPB 00000000 00000210 00000A30 0000000000015BC0 00000000 0
--- the rest of the recording ---

服务器端处理程序:

    @Path(value = "multipart")
    @POST
    @Consumes(MediaType.MULTIPART_FORM_DATA)
    @Produces(MediaType.APPLICATION_JSON)
    public Response receiveFileAndMetadataAsMultipart(
            @FormDataParam(RECORDING) InputStream recordingIinputStream,
            @FormDataParam(RECORDING) FormDataContentDisposition callRecordingDispositionHeader,
            @FormDataParam(QUEUE) String queue,
            @FormDataParam(DATETIME) String datetime) throws JSONException, ParseException, IOException {

        //do stuff with my recording and metadata
        //...

        JSONObject response = new JSONObject();
        return Response.status(Response.Status.OK).entity(response).build();
    }

当我尝试仅发送文件并且内容类型不是 multipart/form-data 而是 application/octet-stream 时,它可以正常工作。 (我的意思不是这个处理程序,而是一个接受八位字节流的处理程序)尽管请求非常相似。我也会发布八位字节流的请求和代码,也许它会有所帮助:

PUT /rest/myapi/recording HTTP/1.1
Accept: application/json
Accept-Language: en-US
Content-Type: application/octet-stream
Cookie: JSESSIONID=a5f5cfa7329142158766a6182645; JSESSIONIDSSO=BAFA3371F6D14A179B0BA6216DD6C119
Host: localhost:8181
Connection: close
User-Agent: Paw/2.2.2 (Macintosh; OS X/10.10.5) GCDHTTPRequest
Content-Length: 55414

ID3BTT2test3_2callsCOMengiTunPGAP0TENiTunes 12.3.0.44COMhengiTunNORM 0000038A 0000038A 00001B3D 00001B3D
--- the rest of the recording ---

方法:

    @Path(value = "recording")
    @PUT
    @Consumes(MediaType.APPLICATION_OCTET_STREAM)
    @Produces(MediaType.APPLICATION_JSON)
    public Response receiveRecording(InputStream callRecordingInputStream) throws IOException, JSONException {

        //do stuff with my recording
        //...

        JSONObject response = new JSONObject();              
        return Response.status(Response.Status.OK).entity(response).build();
    }

有人知道出了什么问题吗?我在网上的几个地方发现了这种多部分的方法,所以我想它应该像那样工作。

顺便说一句,我也尝试删除所有元数据并仅发送录音,但问题是一样的。

【问题讨论】:

  • 你能打印 ParseException 的堆栈跟踪吗?
  • 测试this 看看它是否有效。如果是这样,请尝试生成一个我们可以测试的失败示例。
  • 无限感谢@peeskillet,感谢您的代码,我找到了问题所在。您的代码运行良好,因此我尝试将处理程序方法复制到该测试类,当我注意到 Idea 为我的 FormDataContentDisposition 加上了完整的包名,而您的方法中的同一个类没有前缀时......我的导入错误...... . 现在我觉得超级笨,我应该多检查生成的导入......但无论如何,非常感谢:)

标签: java rest jersey-2.0 multipart


【解决方案1】:

感谢@peeskillet 的评论,我发现了这个问题,所以以防万一同样的事情发生在其他人身上:

FormDataContentDisposition 的导入错误。

错误:

import com.sun.jersey.core.header.FormDataContentDisposition;

正确:

import org.glassfish.jersey.media.multipart.FormDataContentDisposition;

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-10-23
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多