我只是创建一个简单的用户登录,使用MongoDB,Backbone和Node with Express。
我一直在查询数据库中的用户凭据,并可靠地确定它们是否存在。
我在这里尝试两件事:
// When user posts to the url
app.post('/save/user', function (req, res) {
// create user object and store email from form
var user = {
email : req.body.email
};
// in my collection users
db.collection('users', function (err, collection) {
// create a variable existence with the value, in lamens terms 'yes it does' or 'no it doesnt'
var existence = findOne(collection, {
$query : {email : user.email}
});
});
};
// findOne function passing the collection and the query object
function findOne(coll, query) {
var cursor = coll.find(query).limit(1);
return cursor.hasNext() ? cursor.next() : null;
}
所以这是我一直在尝试的第一种方式。事情是,我不明白为什么游标没有'next(),hasNext(),findOne(),forEach()'和javascript环境的其他方法,但只有mongo shell。
我的问题是,如何在我的Node.js应用程序中访问这些方法?
我试过的第二种方式:
//当用户发布到网址时 app.post('/ save / user',function(req,res){
// create user object and store email from form
var user = {
email : req.body.email
};
// in my collection users
db.collection('users', function (err, collection) {
// Have a look for the email entered
var query = collection.find({
$query : {email : user.email}
}).limit(1);
// If it's true, then send response
query.each( function (err, item) {
// If the item does exists, then send back message and don't insert. Otherwise, insert.
if(item !== null) {
console.log('Item does not equal null : ', item);
res.send('The email : ' + item.email + ' already exists');
} else {
console.log('Item does equal null : ', item);
collection.insert(user);
res.send('New user with email : ' + user.email + ' was saved');
}
});
});
};
这个问题是,它总是会在某个时刻返回null,所以我要警告用户'它已经存在',然后下一次将为null,这样就可以保存电子邮件。
我认为我错过了这一点,所以正确方向上的一点很好。
非常感谢提前!
我已经研究过一个解决方案,但仍然必须忽略这一点。
我正在进行插入操作,使用safe:true传递我的用户对象,但是虽然可以输入多个用户对象,但它仍然只查找相同的ID; s。我尝试使用新的ObjectID()创建一个id,但我仍然不明白用户是否输入了他们的电子邮件地址,然后尝试创建一个具有相同电子邮件的新用户,它会为该条目创建一个新ID。
通过执行findOne,我可以看到它是否容易存在,我看不出如何使用insert。
app.post('/register/user', function (req, res) {
// Store user details in object
var user = {
username : req.body.user,
email : req.body.email,
password : req.body.password
};
db.collection('users', function (err, collection) {
collection.insert(user, {safe : true}, function (err, doc) {
console.log('what is doc : ', doc);
if(!err) {
res.writeHead(200, {
"Content-Type" : "text/plain",
"Message" : "New user added",
"Access-Control-Allow-Origin" : "*"
});
} else {
console.log('Error is : ', err);
res.writeHead(200, {
"Content-Type" : "text/plain",
"Message" : "User already exists",
"Access-Control-Allow-Origin" : "*"
});
}
res.end();
});
});
});
答案 0 :(得分:2)
如果您使用Native Node.JS MongoDB driver,则有collection.findOne()方法,而cursors确实有nextObject()
和each()
方法等同于shell方法{ {1}}和hasNext()
。 mongo shell等价物的实现/命名在驱动程序之间可能略有不同,但您应该能够将mongo shell示例转换为Node.JS。
至于保存新用户...而不是在插入之前查询用户,最好在forEach()
字段和insert into the collection上添加唯一索引{{1} }。如果插入因电子邮件重复而失败,则可以处理email
结果。如果在插入之前执行查询,则存在潜在的竞争条件,当您检查电子邮件时,该电子邮件可能不存在,但在您执行插入时确实存在。