我需要Loopback远程方法返回null

时间:2018-11-19 14:59:13

标签: javascript node.js loopbackjs

因此,我正在学习NodeJ的回送,并且尝试使用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;
    
      }));
      }

我确定我在这里缺少任何帮助,我们将不胜感激。 谢谢。

1 个答案:

答案 0 :(得分:0)

请注意,LoopBack远程方法是异步的,因此结果必须通过第二个回调参数传递,而不是作为返回值。

 User.login = function(username, password,cb){
    User.findOne({where:{username: username}}, function(err, user){
        // ** DON'T FORGET TO HANDLE ERRORS **
        if (err) return cb(err);

        console.log(JSON.stringify(user));

        if(user === null){
            console.error('User not found');
            // ** THE FIRST ARG IS "error", THE SECOND ARG IS "result"
            cb(null, 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 cb(null, null);
        }
        console.log('User Authenticated');

        cb(null, user);
    });
}

要解释您观察到的行为:在登录的实现中,您始终返回由findOne找到的用户,请参见此处:

    User.findOne({where:{username: username}}, function(err, user){
        cb(null, user);

        // none of the code below matters, because the result
        // has been already set via `cb(null, user)`
    }