【发布时间】:2018-11-19 23:25:18
【问题描述】:
所以我正在学习 NodeJs 的 Loopback,我正在尝试使用 bcrypt lib 进行身份验证。 如果找不到用户或密码不匹配,我需要我的登录远程方法返回空值。
我的登录实现是:
User.login = function(username, password,cb){
User.findOne({where:{username: username}}, function(err, user){
cb(null, user);
console.log(JSON.stringify(user));
if(user === null){
console.error('User not found');
return null;
}
console.log('User found');
if(!bcrypt.compareSync(password, user.password)){
console.error('Illegal Password');
user = null;
console.log('USER SHOULD BE NULL =======> '+JSON.stringify(user));
return user;
}
console.log('User Authenticated');
return user;
});
}
实际上,如果找到用户,则应为 null 的 console.log 实际上为 null,但是在 auth.service 函数中,如果密码不匹配,则应接收 null 值,但它确实接收了用户。
login(username: string, password: string) {
return this.http.post(this.configService.apiUrl + '/users/login', { username: username, password:password })
.pipe(map(user =>{
console.log('AUTHSERVICE USER SHOULD BE NULL ===========> '+ JSON.stringify(user));
//THIS USER IS NEVER NULL IF USER IS FOUND!!! EVEN IF PASSWORD IS NOT MATCHED
if(!user || user === null){
console.error('Invalid credentials');
return;
}
sessionStorage.setItem('currentUser', JSON.stringify(user));
this.loggedIn.next(true);
this.router.navigate(['/']);
return user;
}));
}
我确定我在这里遗漏了一些东西,任何帮助将不胜感激。 谢谢。
【问题讨论】:
-
什么是
cb(User.login的 3d 参数)?怎么调用User.login方法? -
cb 是远程方法在 LoopBack 中使用的回调函数。 login方法由它的api端点调用:this.configService.apiUrl + '/users/login'
标签: javascript node.js loopbackjs