Yah*_*man 13 mongoose mongodb node.js passport.js
我有这个代码:
user.findOne( { 'email' : email }, function( err, User )
{
if ( err )
{
return done(err);
}
if ( !User )
{
return done(null, false, { error : "User not found"});
}
if ( !User.hasOwnProperty('local') || !User.local.hasOwnProperty('password') )
{
console.log("here: " + User.hasOwnProperty('local')); // displays here: false
}
if ( !User.validPass(password) )
{
return done(null, false, { error : "Incorrect Password"});
}
return done(null, User);
});
Run Code Online (Sandbox Code Playgroud)
由于该应用程序支持其他类型的身份验证,因此我有一个用户模型,其中包含一个名为local的嵌套对象
local : { password : "USERS_PASSWORD" }
Run Code Online (Sandbox Code Playgroud)
所以在登录期间我想检查用户是否提供了密码,但我遇到了这个有趣的问题.我的测试对象如下所示:
{ _id: 5569ac206afebed8d2d9e11e,
email: 'test@example.com',
phno: '1234567890',
gender: 'female',
dob: Wed May 20 2015 05:30:00 GMT+0530 (IST),
name: 'Test Account',
__v: 0,
local: { password: '$2a$07$gytktl7BsmhM8mkuh6JVc3Bs/my7Jz9D0KBcDuKh01S' } }
Run Code Online (Sandbox Code Playgroud)
但console.log("here: " + User.hasOwnProperty('local'));打印here: false
我哪里做错了?
Jas*_*ust 20
这是因为从mongoose返回的文档对象不直接访问属性.它使用原型链从而hasOwnProperty返回false(我大大简化了这一点).
您可以执行以下两项操作之一:使用toObject()将其转换为普通对象,然后您的检查将按原样执行:
var userPOJO = User.toObject();
if ( !(userPOJO.hasOwnProperty('local') && userPOJO.local.hasOwnProperty('password')) ) {...}
Run Code Online (Sandbox Code Playgroud)
或者您可以直接检查值:
if ( !(User.local && User.local.password) ) {...}
Run Code Online (Sandbox Code Playgroud)
由于这两个属性都不具有虚假值,因此如果填充它们,它应该用于测试.
编辑:我忘了提到的另一个检查是使用Mongoose的内置get方法:
if (!User.get('local.password')) {...}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2925 次 |
| 最近记录: |