[英]How to save uploaded image from multer to mongodb in nodejs
我需要將用戶信息從注冊表單保存到 mongodb。 除圖像文件外,一切正常。 我正在使用 Multer 將圖像從表單上傳到服務器。
還可以在用戶登錄后在個人資料頁面中顯示該圖像。
下面是代碼:
注冊.ejs:
<form action="/signup" method="post" enctype="multipart/form-data">
<label for>Profile Picture</label>
<input type="file" name="image"><br><br>
<label for>Name</label>
<input type="text" name="name"><br><br>
<label for>Email</label>
<input type="email" name="email"><br><br>
<label for>Password</label>
</form>
路線.js:
var multer = require('multer');
var storage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, './uploads');
},
filename: function (req, file, cb) {
cb(null, file.originalname);
}
});
var upload = multer({ storage: storage });
module.exports = function(app, passport) {
app.post('/signup', upload.single('image'), passport.authenticate('local-signup', {
successRedirect : '/login',
failureRedirect : '/',
failureFlash : true
}));
圖像上傳到 /uploads 文件夾中。
但是如何獲取該圖像並將其保存在 mongodb 中。 我正在使用 passport.js,下面是保存發布數據的代碼。
用戶模型.js:
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var userSchema = new Schema({
image: {
data : Buffer,
contentType : String
},
name: {
type: String,
},
email: {
type: String,
},
password: {
type: String,
}
});
護照.js:
passport.use('local-signup', new LocalStrategy({
usernameField : 'email',
passwordField : 'password',
passReqToCallback : true
},
function(req, email, password, done) {
User.findOne({ 'email' : email }, function(err, user) {
if (err) {
//errorLogger.error(err);
return done(err);
}
if (user) {
return done(null, false, req.flash('signupMessage', 'Email already exists.'));
} else {
var newUser = new User();
//newUser.image = "dont know how to get image from /uploads"
newUser.name = req.body.name;
newUser.email = req.body.email;
newUser.password = req.body.password;
newUser.save(function(err) {
if (err)
throw err;
return done(null, newUser, req.flash('signupMessage', 'User created'));
});
}
});
您可以創建自己的中間件來處理上傳中間件並獲取文件名。
我還建議在上傳圖片的末尾添加一些隨機字符串,以防止重名。
app.post('/signup', middleware , passport.authenticate('local-signup', {
successRedirect : '/login',
failureRedirect : '/',
failureFlash : true
}));
中間件
function middleware(req, res, next) {
var imageName;
var uploadStorage = multer.diskStorage({
destination: function (req, file, cb) {
cb(null, './uploads');
},
filename: function (req, file, cb) {
imageName = file.originalname;
//imageName += "_randomstring"
cb(null, imageName);
}
});
var uploader = multer({storage: uploadStorage});
var uploadFile = upload.single('image');
uploadFile(req, res, function (err) {
req.imageName = imageName;
req.uploadError = err;
next();
})
}
你可以使用 req.imageName
passport.use('local-signup', new LocalStrategy({
usernameField : 'email',
passwordField : 'password',
passReqToCallback : true
},
function(req, email, password, done) {
User.findOne({ 'email' : email }, function(err, user) {
if (err) {
//errorLogger.error(err);
return done(err);
}
if (user) {
return done(null, false, req.flash('signupMessage', 'Email already exists.'));
} else {
var newUser = new User();
newUser.image = req.imageName;
newUser.name = req.body.name;
newUser.email = req.body.email;
newUser.password = req.body.password;
newUser.save(function(err) {
if (err)
throw err;
return done(null, newUser, req.flash('signupMessage', 'User created'));
});
}
});
如果您使用的圖像格式為“jpeg / png”並且小於 16mb,則可以使用此 github 存儲庫,它是一個有助於將圖像輕松保存到 mongodb 的模塊,並且沒有 GRIDFS 的復雜性,但以防萬一你的文件大於 16mb,你需要使用 GRIDFS,
這是 github 存儲庫的鏈接,用於小於 16 mb 的圖像(也適用於 React)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.