节点在下载后写入损坏的.xlsx文件

时间:2016-11-02 11:22:36

标签: node.js express xlsx xls exceljs

我正在使用" xlsx"服务器端的模块。我的服务器从客户端获取.xlsx文件。使用multipart上传文件时效果很好。但是,当我尝试从Google云端硬盘或Dropbox下载文件时,我总是会收到损坏的.xlsx文件。

从Google云端硬盘下载文件的功能。

service.files.get({
                auth: auth,
                fileId: fileId,
                alt: 'media'
            }, function (err, response) {
                if (err) {
                    res.status(400).json({message: "Error while downloading"});
                } else {                        
                    fs.writeFileSync(req.body.fileName, response);
                    var data = xlsParser.parse(fs.readFileSync(req.body.fileName));
                    res.json(data);
                }
            });

解析器代码

module.exports = {
parse: function (file) {
    var workSheet = xlsx.read(file, {});
    return Object.keys(workSheet.Sheets).map(function(name) {
        var sheet = workSheet.Sheets[name];
        return {name, data: xlsx.utils.sheet_to_json(sheet, {raw: false})}
    })
}}

Google云端硬盘中的文件有效。用节点写它们之后我就不能打开它们。 我遇到错误

\node_modules\jszip\lib\dataReader.js:25
        throw new Error("End of data reached (data length = " + this.length + ", asked index = " + (newIndex) + "). Corrupted zip ?");
        ^

Error: End of data reached (data length = 1771452, asked index = 1771464). Corrupted zip ?

1 个答案:

答案 0 :(得分:0)

虽然使用xlsx和exceljs模块,但必须同时保证writeFileSync和readFileSync,并且在执行下一个操作之前,您应该等待它们解决。