如何解决将PDF从服务器发送到客户端
我正在尝试从Google云端硬盘访问pdf。不管此访问是下载还是查看,都没有关系,只需要可用即可。
我正在使用带有Express和Google Drive API的Javascript和NodeJS。
我具有以下功能,可在其中下载pdf。但是愚蠢的我认为这是正确的,因为它在本地有效。然后,当我部署它时,我意识到目标文件路径不再有意义。
function downloadDoc (sourceID,targetName,callback) {
const dest = fs.createWriteStream(`${os.homedir()}/downloads/`+targetName);
drive.files.get(
{sourceID,alt: 'media'},{responseType: 'stream'},(err,res) => {
if (err) {
console.error(err);
}
res.data.on('end',() => {
console.log('Done downloading file.');
callback();
})
.on('error',err => {
console.error('Error downloading file.');
throw err;
})
.pipe(dest);
});
}
所以我需要做的是从此函数获取数据(或响应?)并将其发送到客户端。我认为这很简单,但是作为一个简单的人,我发现自己陷于困境。我这样做的目的是,用户可以单击客户端上的链接,请求该URL并调用该函数以下载pdf。
app.get('/download_pdf',(req,res) => {
downloadDoc(documentID,'docName.pdf',()=>{
console.log("downloaded pdf");
});
res.end();
});
我想我需要更改提供给pipe()的参数,因为显然我不能使用文件路径。
我检查过的类似问题:
Display Pdf in browser using express js
How to send a pdf file from Node/Express app to the browser
Send pdf via express to js client and download
尽管这些问题与此有关,但我认为我的问题是由于对回调或请求/响应缺乏了解。我想正确地学习这一点-不仅要寻求答案-而且,由于时间紧迫,我很快需要解决方案。
解决方法
您应该能够简单地将返回的可读流通过管道传递给express res
对象(这是可写流):
app.get('/download_pdf',(req,res) => {
drive.files.get({
fileId: "your-file-id-here",alt: 'media'
})
.on('end',function () {
console.log('Done');
})
.on('error',function (err) {
console.log('Error during download',err);
})
.pipe(res);
});
编辑:
如here所述,drive.files.get
确实返回了承诺。因此,您需要将其更改为:
app.get('/download_pdf',res) => {
drive.files.get({
fileId,alt: 'media'
},{
responseType: 'stream'
}).then(response => {
response.data
.on('end',function () {
console.log('Done');
})
.on('error',function (err) {
console.log('Error during download',err);
})
.pipe(res);
});
});
,
所以我想出了办法。我不确定这是否是不好的做法,但似乎可行。我通过将一个称为响应,将一个称为res来区分两个响应对象。
app.get('/download_pdf',res) => {
const docId = req.query.id;
drive.files.get({
fileId: docId,err);
})
.pipe(res);
});
});
在其他人遇到类似问题的情况下发布此信息。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。