使用multer
成功上传文件后,我无法重定向页面。通过文件上传,我还将一些文本保存到数据库中。这是我的代码。
问题:
当文件和内容保存在数据库中时,如何将页面重定向到新的URL?
我目前正在使用res.redirect('product/item');
,但没有任何反应。我也尝试使用res.render
,但页面没有重定向。
Multer
将文件上传到Amazon S3
的方法
var upload = multer({
storage: multerS3({
s3: s3,
bucket: 'nameofthebucket',
metadata: function (req, file, cb) {
var ext = file.originalname.split('.').pop();
cb(null, {fieldName: 'file.fieldname' + '.' + ext});
},
filename: function(req,file,cb){
var ext = file.originalname.split('.').pop();
cb(null, Date.now() + '.' + ext);
},
key: function (req, file, cb) {
var ext = file.originalname.split('.').pop();
cb(null, Date.now() + '.' + ext);
}
})
})
var upload = upload.array('fileup', 10);
负责上传文件和内容的代码
router.post('/uploadfileandcontent',function(req,res,next){
upload(req,res,function(err) {
if(err) {
} else {
saveRecordsToDB(req, function(err,data){
if (err) {
res.redirect('/errorpage');
} else {
res. redirect('product/item');
}
});
}
});
});
将记录保存到数据库并进行回调的功能
function saveRecordsToDB (req, callback){
var args = {
data: {
"name" : req.body.name, //
"age" : req.body.age
},
headers: { "Content-Type": "application/json" }
};
// registering remote methods
client.registerMethod("postMethod", "http://url/uploadfileandcontent", "POST");
var req =client.methods.postMethod(args, function (data, response) {
callback(null, 'success?');
});
req.on('error', function (err) {
console.log('error');
});
}
注意:我还使用NODE REST CLIENT发送http请求。
答案 0 :(得分:1)
这应该有效。告诉我,如果没有。
router.post('/uploadfileandcontent', function(req,res,next){
upload(req,res,function(err) {
if(err) {
res.send('Error while uploading.');
}
saveRecordsToDB(req, function(err,data){
if (err) {
console.log(err);
req.flash('error', { msg: 'Error while saving data.' }); // Flash message -> need to configure your template to show it
}
// Saved to DB
req.flash('success', { msg: 'Saved' });
res.redirect('/product/item'); // go to this page
});
});
});
<强>更新强>
您需要包含const flash = require('express-flash');
才能使用Flash消息。然后,您可以将其加载到您的应用中,如下所示:app.use(flash());
。 app
express
加载如下:const app = express();
。
在HTML中,您将以数组形式访问它。使用 Jade :
的示例//success
if messages.success
for success in messages.success
div #{success.msg} // Saved
//Error
if messages.errors
for error in messages.errors
div #{error.msg} // Error while saving data.