如何摆脱上传文件中的WebKitFormBoundary

时间:2015-06-08 20:44:27

标签: java angularjs jersey multipartform-data

我正在网络应用中实施文件上传

前端是用 angularJS 编写的,并使用 angular-file-upload 包(可在此链接https://github.com/nervgh/angular-file-upload找到的包)

后端是 Java / Jersey Web服务。

我的问题是:

上传的文件包含 WebKitFormBoundary 页眉和页脚,如下所示:

------WebKitFormBoundarylqskdjlqksdjl
Content-Disposition: form-data; name="upload"; filename="foo.bar"
Content-Type: multipart/form-data

因此,我不确定我是上传文件还是请求。当然,我的后端应用程序认为上传的文件已损坏,除非删除这些行(现在手动),否则不会显示它们。

底线是:我如何摆脱上传文件中的页眉和页脚?

以下是一些代码示例。

前端

再次:angularJS angular-file-upload

item.headers = {
    'Content-Disposition': 'attachment; filename="' + item.file.name + '"',
    'Content-Type': 'multipart/form-data'
};

后端

和Java / Jersey

@POST
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.MULTIPART_FORM_DATA)
@Path("someurl/{fileName}")
public Artifact uploadArtifact(InputStream uploadedStream, @PathParam("fileName") String fileName) throws Exception;

注意

我想知道我的angularJS部分中的Content-Disposition: attachment是否可以解决这个问题?

它应该是Content-Disposition: form-data

提前谢谢!

1 个答案:

答案 0 :(得分:3)

您需要放置@FormDataParam注释才能正确处理边界。

@POST
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.MULTIPART_FORM_DATA)
@Path("someurl/{fileName}")
public Artifact uploadArtifact(
    @FormDataParam("file") InputStream uploadedStream,
    @FormDataParam("file") FormDataContentDisposition fileDetails,
    @PathParam("fileName") String fileName) throws Exception;