Has*_*bas 1 amazon-web-services node.js express aws-lambda aws-api-gateway
我的 API 端点返回一个从 S3 流式传输的 Excel 文件。它可以在本地运行,但在 API 网关上测试时文件已损坏。这是我的 API 代码:
const downloadContentFromS3 = async function(bucket, file) {
return new Promise((resolve, reject) => {
streamFileFromS3(bucket, file, (error, s3buffer) => {
if (error) return reject(error);
return resolve(s3buffer);
});
});
};
const streamFileFromS3 = async function(bucket, fileName, callback) {
const params = {
Bucket: bucket,
Key: fileName,
};
const buffers = [];
const stream = s3.getObject(params).createReadStream();
stream.on('data', data => buffers.push(data));
stream.on('end', () => callback(null, Buffer.concat(buffers)));
stream.on('error', error => callback(error));
};
downloadExcelFile: async (req, res) => {
try {
const fileName = 'myFilename';
const workbook = await downloadContentFromS3(
'bucket-name'
fileName
);
const workbook = xlsx.read(buffer);
res.setHeader('Content-disposition', `attachment; filename=${fileName}`);
res.setHeader(
'Content-type',
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
);
const wbout = xlsx.write(workbook, { bookType: 'xlsx', type: 'buffer' });
res.status(200).send(Buffer.from(wbout));
} catch (error) {
throw new OriolaError(error.message);
}
},
Run Code Online (Sandbox Code Playgroud)
此外,尝试将RESPONSE HEADER设置为 Content-Type 和 Content-Disposition 但无济于事。问题似乎仍然存在。任何想法和帮助表示赞赏。
编辑:我还尝试*/*在设置中设置二进制类型,但这也没有帮助。
API Gateway 和 Lambda 在它们之间以 base64 形式发送文件。这与您是否在 API Gateway 上设置二进制媒体类型无关,因为 API Gateway 会在 Base64 和二进制之间进行转换。
S3 getObject 获取一个二进制文件,但这对于您的问题来说是一个没有实际意义的点,因为您仍在使用 xlsx 创建二进制文件。
您当前正在做的是将未转换为 Base64 数据的二进制数据发送。
您所需要做的就是将文件作为 Base64 缓冲区而不是二进制缓冲区返回。
所以
res.status(200).send(Buffer.from(wbout));
Run Code Online (Sandbox Code Playgroud)
变成
res.status(200).send(Buffer.from(wbout).toString('base64'));
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
4324 次 |
| 最近记录: |