变量未覆盖node.js

塞纳非克斯
    router.post('/loginv', function (req,res) {
  var id = req.body.id;
  var pass = req.body.pass;

  if(login.login(id,pass)=='validated'){
    res.sendfile('views/welcome.html');
  }else{
    res.send('dont give up');
  }

  var result = login.login(id,pass);
  console.log(result);
});

module.exports={


   login : function(id,pass){
        var q = "SELECT * FROM user where id = ? and pass = ?";
        var ret = 'default';

        DB.DB.query(q, [id,pass], function (error,result) {
            if(error){
                console.log('not found');
                ret = 'unrecognized';
            } else{
                console.log('found');
                ret =  'validated';
            }
        });

        return ret;
    }};

console.log:

    GET /login 304 4.028 ms - -
default
POST /loginv 200 40.558 ms - 12
found
found

如您所见,以下代码返回的值ret并未更改,尽管它正确执行了函数的过程。.我是Node js和js的新手,所以任何评论和建议对thx都是有帮助的:)

拉帕多瓦尼

DB.query()是异步的,因此login函数在返回之前不要等待代码的执行ret您需要向登录方法添加回调(或使用Promise)。

工作代码:

module.exports = {
  login : function(id,pass,cb){
      var q = "SELECT * FROM user where id = ? and pass = ?";

      DB.DB.query(q, [id,pass], function (error,result) {
          if(error){
              console.log('not found');
              cb(error, 'unrecognized');
          } else{
              console.log('found');
              cb(null, 'validated');
          }
      });
  }
};

另一个文件:

router.post('/loginv', function (req,res) {
  var id = req.body.id;
  var pass = req.body.pass;

  login.login(id,pass, function(err, result) {
    if (err) {
        console.log(err);
        res.send('dont give up');
        return;
    }

    if (result === 'validated') {
      res.sendfile('views/welcome.html');
    }else{
      console.log('Unknown error');
    }
  })
});

我建议您阅读此处发布的链接以及该问题,它可以使您对回调和Promise有所了解。

PS:我不知道您要为DB使用哪个库,但是如果该库不适合您,则必须在执行查询之前清理输入

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章