我有一个提供文件的Java Web应用程序:
@RequestMapping(value = "/pdf/download", method = RequestMethod.GET)
public void download(
HttpServletRequest request,
HttpServletResponse response,
@RequestParam(value = "id", required = true) Long id) throws IOException {
File pdfFile = pdfFileManager.getFromId(id);
response.setContentType("application/pdf");
response.addHeader("Content-Disposition", "attachment; filename=download");
response.setContentLength((int) pdfFile.length());
FileInputStream fileInputStream = null;
OutputStream responseOutputStream = null;
try {
fileInputStream = new FileInputStream(pdfFile);
responseOutputStream = response.getOutputStream();
int bytes;
while ((bytes = fileInputStream.read()) != -1) {
responseOutputStream.write(bytes);
}
responseOutputStream.flush();
} finally {
fileInputStream.close();
responseOutputStream.close();
}
}
我在客户端检索文件,base64使用FileReader对其进行编码:
$.ajax({
url: "/pdf/download?id=" id,
dataType: "application/pdf",
processData: false
}).always(function(response) {
if(response.status && response.status === 200) {
savePdf(response.responseText, "download_" id);
}
});
function savePdf(pdf, key) {
var blob = new Blob([pdf], {type: "application/pdf"});
var fileReader = new FileReader();
fileReader.onload = function (evt) {
var result = evt.target.result;
try {
localStorage.setItem(key, result);
} catch (e) {
console.log("Storage failed: " e);
}
};
fileReader.readAsDataURL(blob);
}
问题是本地存储中保存的值不正确.编码数据与我使用this snip上传PDF时得到的数据不同.我不知道问题是我如何在客户端中提供文件或编码过程.
存储的值是这样的
data:application/pdf;base64,JVBERi0xLjQKJe /ve /ve /ve /vQoxIDAgb...
代替
data:application/pdf;base64,JVBERi0xLjQKJeHp69MKMSAwIG9iago8PC9Ue...
解决方法: 解决了将请求的响应类型设置为blob的问题:
var xhr = new XMLHttpRequest();
xhr.open("GET", "/pdf/download?id=" id);
xhr.responseType = "blob";
xhr.onload = function() {
if(xhr.status && xhr.status === 200) {
savePdf(xhr.response, "download_" id);
}
}
xhr.send();
function savePdf(pdf, key) {
var fileReader = new FileReader();
fileReader.onload = function (evt) {
var result = evt.target.result;
try {
localStorage.setItem(key, result);
} catch (e) {
console.log("Storage failed: " e);
}
};
fileReader.readAsDataURL(pdf);
}
来源:https://www./content-1-275951.html
|