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);
});