【发布时间】:2019-02-19 16:53:15
【问题描述】:
在我的ember.js webapp 中,用户可以选择下载一个 zip 文件。单击按钮时,将触发一个操作,该操作将请求发送到后端服务器,后端服务器生成 zip 并将其返回。理想情况下,应该会自动下载 zip。
在我的后端端点我返回
return Response
.ok(FileUtils.readFileToByteArray(new File(tmpZipFilename))) // tmpZipFilename is a String
.type("application/zip")
.header("Content-Disposition", "attachment; filename=\"" + finalZipFilename + "\"")
.build();
在前端我有(改编自here)
submit() {
var formData = new FormData(this);
let token = this.get('session.data.authenticated.token');
jquery.ajax({
url: `myUrl`,
data: formData,
processData: false,
contentType: false,
beforeSend: function(xhr) {xhr.setRequestHeader('Authorization', `Bearer ${token}`)},
type: 'POST',
success: function(data) {
var blob = new Blob([data], {type: 'application/zip'});
let a = document.createElement("a");
a.style = "display: none";
document.body.appendChild(a);
let url = window.URL.createObjectURL(blob);
a.href = url;
a.download = 'myFile.zip';
a.click();
window.URL.revokeObjectURL(url);
},
failure: function() {
// other stuff
}
})
}
响应头如下:
HTTP/1.1 200 OK
X-Powered-By: Undertow/1
Cache-Control: no-store
Date: Tue, 19 Feb 2019 16:34:35 GMT
Server: WildFly/10
Content-Type: application/zip
Content-Disposition: attachment; filename="filename.zip"
Connection: close
Transfer-Encoding: chunked
我已确认后端部分中的 tmpZipFilename 确实正确指向了正确的 zip 文件。当用户单击下载按钮时,确实会下载一个名为myFile.zip 的文件。但是,下载的文件不可解压缩,并且与tmpZipFilename 指向的正确文件的大小不同。我做错了什么?
【问题讨论】:
-
您没有正确连接这些字符串。 "附件;文件名=\"" + finalZipFilename + "\""
-
你能用文本编辑器看一下 zip 文件吗?可能是服务器出错的html文件。
-
看起来像二进制数据,有很多
�s -
我在文本编辑器视图上运行了一个比较好的和坏的拉链。它们几乎相同,只是坏 zip 中的每一行都缺少一些随机的
�s
标签: javascript java jquery ajax ember.js