1

我使用 jqgrid 插入数据。该数据还包括图像。上传没有问题,但我很难组合数据和重命名文件才能将其保存到数据库中。我尝试使用控制台检查它,似乎我的系统尝试调用插入模型两次。这是输出:

console.log (content.record);

{
id: '_empty',
Logo: undefined,
Name: 'foo'
}
{
id: 'undefined',
Logo: 'public/foo.jpeg',     
Name: 'undefined'
}

//它总是试图插入两次。也许是因为 for(...);

这是我重命名上传文件并将其保存到包含数据的数据库中的代码。

exports.Upload = function(req,res){



        for(var i in req.files)
            var tmp_path = req.files[i].path;
        for(var i in req.files) 
        var target_path = newpath + req.files[i].name;

                fs.rename(tmp_path, target_path, function(err) {  
                fs.unlink(tmp_path, function() {

                    var content = {};
                    content.table = "teams";
                    content.record = {id:req.body.id,Logo:target_path,Name:req.body.Name};


                    //console.log(target_path);
                console.log(content.record);

                        req.model.insert(content,function(err,result){
                        result = (result?true:false);

                        });
                   });
            });
};

请忍受我糟糕的英语,任何帮助将不胜感激。

4

1 回答 1

0

for执行异步操作时不要使用标准循环。使用 async 模块代替async.eachSeries

var inspect = require('eyespect').inspector();
var fs = require('fs')
var path = require('path')
var async = require('async')
exports.Upload = function (req, res) {
  var files = req.files
  async.eachSeries(
    files,
    function (file, cb) {
      var filePath = file.path
      var filename = file.filename
      var outputPath = path.join(__dirname, 'uploads/', filename)
      fs.rename(filePath, outputPath, function (err, reply) {
        if (err) { return cb(err) }
        var content = {};
        content.table = "teams";
        content.record = {
          id:req.body.id,
          logo:outputPath,
          name:
          req.body.Name
        };
        //console.log(target_path);
        console.log(content.record);
        req.model.insert(content,function(err,result){
          if (err) { return cb(err) }
          inspect(result, 'insert result')
          cb()
        })
      })
    },
    function (err) {
      if (err) {
        inspect(err, 'error saving files to database')
        res.send(500, err)
        return
      }
      res.send(200, 'files saved correctly')
    })
}

要为上面的示例安装所需的依赖项,请执行 npm install -S eyespect async

于 2013-05-02T16:28:11.890 回答