我正在网络应用中实施文件上传。
前端是用 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
?
答案 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;