NodeJS:将重命名的上传图像保存到数据库中

时间:2013-05-02 15:03:23

标签: json node.js jqgrid express

我使用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);

                        });
                   });
            });
};

请与我的不良英语一起生活, 任何帮助都会得到很多赞赏。

1 个答案:

答案 0 :(得分:0)

执行异步操作时,请勿使用标准for循环。使用异步模块代替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