首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何等待节点的回调函数执行

如何等待节点的回调函数执行
EN

Stack Overflow用户
提问于 2020-08-07 01:05:02
回答 1查看 428关注 0票数 0

我正在尝试使用node上传文件/存储,并将文件保存在Gird FS中。下面是代码示例。上传功能工作得很好。由于节点的异步特性,响应将立即发送回浏览器。我希望在回调函数执行之前保持响应。注意:我也尝试在回调函数内部发送最终响应,但仍然不起作用。

请抛出一些想法。

代码语言:javascript
复制
const multer = require("multer");
const GridFsStorage = require("multer-gridfs-storage");
const mongoose = require("mongoose");
mongoose.connect(CONFIG.dbConfig, {useNewUrlParser: true, useUnifiedTopology: true} );

var storage = new GridFsStorage({
  url: CONFIG.dbConfig,
  options: { useNewUrlParser: true, useUnifiedTopology: true },
  file: (req, file) => {
    return {
      bucketName: "xyz",
      filename: `${file.originalname}`
    };
  }
});

const viewPage = (req, res) => {
  try {
    
    var uploadFile = multer({ storage: storage }).single("file");
     uploadFile(req, res, function(err) {
      if (req.file == undefined) {
        return res.send(`You must select a file.`);
      }

      /* code to save anthother Schema */
      fileDetails.save(function(err) {
        if (err) throw err;
      });
      
    });
    
    return res.send(`File has been uploaded.`);
  } catch (error) {
    console.log(error);
    return res.send(`Error when trying upload image: ${error}`);
  }
};

module.exports = {
  getPage:  viewPage
};
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-08-07 01:21:01

您将不得不使用async并等待

代码语言:javascript
复制
// convert multer function to async await
function uploadFile(req) {
    return new Promise(resolve => {
       var uploadFile = multer({ storage: storage }).single("file");
       if (req.file == undefined) {
          return resolve([`You must select a file.`, null]);
       }else {
          // do something
          return resolve([null, data])
       }
    });
}
const viewPage = async (req, res) => {
  try {
     let [err, data] = await uploadFile(req)
      // check error and send response
      // convert do async await similarly for below fileDetails.save  
 
      /* code to save anthother Schema (change this to async await) */
      fileDetails.save(function(err) {
        if (err) throw err;
      });
      
    });
    
    return res.send(`File has been uploaded.`);
  } catch (error) {
    console.log(error);
    return res.send(`Error when trying upload image: ${error}`);
  }
};
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63288522

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档