我正在尝试从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
尽管这些问题与此有关,但我认为我的问题是由于对回调或请求/响应缺乏了解。我想正确地学习这一点-不仅要寻求答案-而且,由于时间紧迫,我很快需要解决方案。
答案 0 :(得分:2)
您应该能够简单地将返回的可读流通过管道传递给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', (req, 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);
});
});
答案 1 :(得分:0)
所以我想出了办法。我不确定这是否是不好的做法,但似乎可行。我通过将一个称为响应,将一个称为res来区分两个响应对象。
app.get('/download_pdf', (req, res) => {
const docId = req.query.id;
drive.files.get({
fileId: docId,
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);
});
});
在其他人遇到类似问题的情况下发布此信息。