2017-07-11 54 views
1

尝试搜索网络2天后仍无法找到具体答案。我有下面的用户路由和模型的node.js代码。如何检查用户名和电子邮件是否从未出现在MongoDB中,并在用户提示消息时提示用户?检查用户名和电子邮件在数据库中是否唯一

型号:

var mongoose = require('mongoose'); 
var bcrypt = require('bcryptjs'); 

// User Schema 
var UserSchema = mongoose.Schema({ 
    username:{type: String , required:true, index: true, unique:true}, 
    email:{type: String, required:true, index: true, unique:true}, 
    password:{type: String, required:true} 
}); 

module.exports = mongoose.model('User', UserSchema) 

路线:

var express = require('express'); 
var router = express.Router(); 
var User = require('../models/user'); 
var bcrypt = require('bcryptjs'); 

// Get Homepage 
router.get('/', function(req, res){ 
    res.render('index'); 
}); 

router.get('/register',function(req,res){ 
    res.render('register'); 
}); 

// submit form 
router.post('/submit', function(req, res){ 

    // retrieve data from posted HTML form 
    var username = req.body.username; 
    var email = req.body.email; 
    var password = req.body.password; 
    var password_confirm = req.body.password_confirm; 

    // express validator 
    req.checkBody('username','Username is required').notEmpty(); 
    req.checkBody('email','Email is required').notEmpty(); 
    req.checkBody('email','Invalid email').isEmail(); 
    req.checkBody('password','Password is required').notEmpty(); 
    req.checkBody('password','Password must contain at least 6 characters').isLength({min:6}); 
    req.checkBody('password_confirm','Password mismatch').equals(req.body.password); 

    // store the errors 
    var errors = req.validationErrors(); 
    if(errors){res.render('register',{errors:errors});} 
    else { 
     // hash password 
     var salt = bcrypt.genSaltSync(10); 
     var hash = bcrypt.hashSync(password, salt); 
     password=hash; 

     // load data into model 
     var newUser = new User ({username:username, email:email, password:password}); 
     // save the new user 
     newUser.save(function(err,newUser){ 
      if(err){console.error(err);} 
      // console.error is same, but in stderr form 
      else{ 
       console.log('new user saved successfully'); 
       console.log(newUser); 
      } 
     }); 
     res.redirect('/'); 
    } 
}); 

module.exports = router; 

回答

2
app.post('/authenticate', function(req, res) { 
    var user = new User({ 
    username: req.body.username 
    }); 

    user.save(function(err) { 
    if (err) { 
     if (err.name === 'MongoError' && err.code === 11000) { 
     // Duplicate username 
     return res.status(500).send({ succes: false, message: 'User already exist!' }); 
     } 

     // Some other error 
     return res.status(500).send(err); 
    } 

    res.json({ 
     success: true 
    }); 

    }); 
}) 

你必须抓住错误,并返回到你的应用程序的前端。以上代码应演示如何使用服务器状态500来实现此目的。对于在网上搜索,这个答案和问题十分相似,这先前的问题:

How to catch the error when inserting a MongoDB document which violates an unique index?

我希望这有助于在一定程度上。

+0

感谢您的回复。但我仍然可以用相同的用户名成功保存新条目到mongodb中。当我使用console.log(err)时,它不会产生任何错误。我检查了您提供的另一个案例的链接,至少发现了该案例的错误消息。你知道我为什么没有犯错吗? – unclegood

+0

,因为您可能没有以相同的方式定义变量。在这里,我看到你正在使用'var errors = req.validationErrors();'尝试控制台记录'错误'并查看实际出现的内容。 – ZombieChowder

相关问题