Node.JS Rethink-DB 检查用户名和电子邮件是否已经存在

Node.JS Rethink-DB check if username and email is already exist

我在基于 RethinkDB Chat 示例的带有 Node 的 login/register 系统上工作时,我发现它不检查用户是否存在电子邮件或用户名,这是一个问题。 当我想解决这个问题时,我无法找出原因,因为 运行 数据库检查需要一个回调函数,这使得它很难实现。

  if (typeof req.user !== 'undefined') {
    res.redirect('/account');
    return;
  }
  if (!validateEmail(req.param('email'))) {
    req.flash('error', 'Not a valid email address!')
    res.redirect('/register');
    return;
  }

  // Add a check for EMAIL/USERNAME here.

  if (req.param('password') !== req.param('password2')) {
    req.flash('error', 'Passwords does not match!')
    res.redirect('/register');
    return;
  }

如果用户的用户名或邮件与将发送的表单中的用户名或邮件相同,我需要什么帮助:

  if (alreadyExists) {
    req.flash('error', 'That username/email is already in use.')
    res.redirect('/register');
    return;
  }

所以主要问题是我必须知道它是否存在于与其他函数相同的函数中,而不是在回调中。感谢您的帮助!

要检查具有给定电子邮件地址的用户是否存在,您必须检查异步的 RethinkDB 数据库。没有回调就无法实现,但还不错!

var r = require('rethinkdbdash')();

function getUserByEmailAddress(emailAddress) {
  return r.db('test').table('user')
    .getAll(emailAddress, {index: 'emailAddress'}).run();
}

app.post('/register', function(req, res) {
  // User already has a session. Not allowed to log in.
  if(req.user) {
    return res.redirect('/account');
  } else if(!validateEmail(req.body.emailAddress)) {
    return res.status(500).send('Not a valid email address'); 
  } else if(req.body.password !== req.body.password2) {
    return res.status(500).send('Passwords do not match'); 
  }

  getUserByEmailAddress(req.body.emailAddress).then(function(user) {
    if(user) {
      res.status(500).send('User with given email address already exists');
    } else {
      // New email address! Encrypt password, add to db, etc.
    }
  })
}

请注意,您必须为此创建一个 secondary index

您或许还应该考虑使用 POST-request instead of a GET-request.

发布表单

我通常处理这种事情的方式是:

User.filter({username:req.body.username}).run().then(function(userArray){ 
   if(userArray[0]){return res.status(500).json({Error : "Username is in use"});} 

我没有 运行 使用回调解决任何问题。您是否有特定原因试图避免它?

编辑: 显然,将我的示例中的用户名替换为您要检查的任何内容,在您的案例中是电子邮件地址。 User 这是我的用户模型。我也同意 Tholle 关于使用 POST 请求的观点。您永远不想在查询 string/URL

中发送用户的 information/credentials