我使用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);
});
});
});
};
请与我的不良英语一起生活, 任何帮助都会得到很多赞赏。
答案 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