将 PDF 从服务器发送到客户端
Send PDF from Server to Client
我正在尝试从 Google 驱动器访问 pdf。这个访问权限是下载还是查看,其实并不重要,只要可用就可以了。
我正在使用 Javascript 和 NodeJS,使用 express 和 google 驱动器 api。
我有以下下载 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);
});
}
所以我需要做的是从此函数中获取数据(或响应?)并将其发送到客户端。我认为这很容易做到,但作为一个简单的人,我发现自己被困住了。我写了这个,目的是用户可以在客户端单击 link,请求此 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
虽然这些问题与此非常相关,但我认为我的问题是由于缺乏对回调的理解或 requests/responses。我想正确地学习这个 - 而不仅仅是寻求答案 - 但事实上,我变得非常紧迫,很快就需要一个解决方案。
您应该能够简单地将 returned 可读流通过管道传输到 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);
});
编辑:
如前所述 ,drive.files.get
做了 return 承诺。所以你需要把它改成:
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);
});
});
所以我想出了一个办法。我不确定这是否是不好的做法,但它似乎有效。我通过将一个称为 response 和一个称为 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);
});
});
如果其他人遇到类似问题,请发布此信息。
我正在尝试从 Google 驱动器访问 pdf。这个访问权限是下载还是查看,其实并不重要,只要可用就可以了。
我正在使用 Javascript 和 NodeJS,使用 express 和 google 驱动器 api。
我有以下下载 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);
});
}
所以我需要做的是从此函数中获取数据(或响应?)并将其发送到客户端。我认为这很容易做到,但作为一个简单的人,我发现自己被困住了。我写了这个,目的是用户可以在客户端单击 link,请求此 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
虽然这些问题与此非常相关,但我认为我的问题是由于缺乏对回调的理解或 requests/responses。我想正确地学习这个 - 而不仅仅是寻求答案 - 但事实上,我变得非常紧迫,很快就需要一个解决方案。
您应该能够简单地将 returned 可读流通过管道传输到 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);
});
编辑:
如前所述 drive.files.get
做了 return 承诺。所以你需要把它改成:
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);
});
});
所以我想出了一个办法。我不确定这是否是不好的做法,但它似乎有效。我通过将一个称为 response 和一个称为 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);
});
});
如果其他人遇到类似问题,请发布此信息。