multer.js
var path = require("path"),
multer = require("multer");
const storage = multer.diskStorage({
destination: function(req, file, next){
next(null, '../public/imgs/');
return;
},
filename: function(req, file, cb){
cb(null, file.fieldname + '-' + Date.now() + path.extname(file.originalname));
}
});
const upload = multer({
storage: storage
});
module.exports = upload;
路由器.js
//handle createPartner route
router.post("/partner/new", upload.single('image'), function(req, res){
console.log(req.file);
console.log(req.body);
req.body.Partner["image"] ="/static/imgs/"+req.file.filename;
req.body.Partner.body = req.sanitize(req.body.Partner.body);
Partner.create(req.body.Partner, function(err, createdPartner){
if(err){
console.log(err);
res.redirect("/admin/partner/new");
}else{
res.redirect("/partners");
}
});
});
我得到以下控制台.log
{ fieldname: 'image',
originalname: 'fb.png',
encoding: '7bit',
mimetype: 'image/png',
destination: '../public/imgs/',
filename: 'image-1521727739861.png',
path: '../public/imgs/image-1521727739861.png',
size: 21532 }
{ Partner: { name: 'test', bio: 'test', image: '', website: 'test' } }
所以 Multer 确实会获取文件,但它不会将其上传到目的地!/public 和/public/imgs 的权限为 777。我搜索的任何地方都使用另一种 multer 方法,但这样我就必须提前指定(单个/多个/任意(,这是不正确的。
您需要包含我在注释中提到的绝对路径。
您可以通过使用以下path.join
轻松完成此操作:
var path = require('path');
var dir = path.join(__dirname, '../public/imgs')
这将连接__dirname
这是当前文件的绝对路径与图像文件。