Javascript NodeJS sendFile从服务器返回空文件
服务器端 我正在尝试从Javascript NodeJS sendFile从服务器返回空文件,javascript,node.js,reactjs,pdf,axios,Javascript,Node.js,Reactjs,Pdf,Axios,服务器端 我正在尝试从NodeJs /** * Exports data to PDF format route. */ app.post('/export/pdf', upload.single('imageBlob'), function (request, response) { var PDF = require('./services/PdfService').PDF; var fileUrl = PDF.generatePDFExport(request.body, r
NodeJs
/**
* Exports data to PDF format route.
*/
app.post('/export/pdf', upload.single('imageBlob'), function (request, response) {
var PDF = require('./services/PdfService').PDF;
var fileUrl = PDF.generatePDFExport(request.body, request.file.buffer);
setTimeout(() => {
response.sendFile(fileUrl);
}, 200);
});
这段代码创建了一个有效的pdf文件(我可以打开它)
但是一些浏览器隐藏了弹出窗口,我想下载一个文件而不是打开它
我检查客户机中的响应,它是一些BLOB
looking响应
客户端
我试图根据响应创建一个文件,但只有一个空的pdf文件
return axios.post('http://172.18.0.2:8001/export/pdf', formData).then(response => {
let blob = new Blob([response.data]);
FileSaver.saveAs(blob, "st-seatmap-shop.pdf");
})
这里有什么错误?在发送文件的服务器端或保存文件的客户端?唯一的问题是向服务器发送请求 默认情况下,服务器返回流,并且为了在客户端上保存文件,响应需要是一个
BLOB
,所以我只是更新了请求
let requestOptions = {
responseType: 'blob'
};
return axios.post('http://172.18.0.2:8001/export/pdf', formData, requestOptions).then(response => {
let blob = new Blob([response.data]);
FileSaver.saveAs(blob, "st-seatmap-shop.pdf");
}).catch(error => {
console.log("error.response is : ", error);
});