Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/video/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 节点JS MySQL身份验证_Javascript_Mysql_Node.js - Fatal编程技术网

Javascript 节点JS MySQL身份验证

Javascript 节点JS MySQL身份验证,javascript,mysql,node.js,Javascript,Mysql,Node.js,我是NodeJS的新手。我正在根据后端MYSQL对用户进行身份验证 下面是身份验证的代码片段 function Authenticate(username, password, fn) { connection.connect(); var user; connection.query('SELECT * from Users where username = ' + connection.escape(username) + ' and pass

我是NodeJS的新手。我正在根据后端MYSQL对用户进行身份验证

下面是身份验证的代码片段

function Authenticate(username, password, fn) {
     connection.connect();
     var user;
     connection.query('SELECT * from Users where username = ' +
         connection.escape(username) + ' and password =' + connection.escape(password),
         function(err, rows) {
             user = rows[0].username;
         });
     if (!user) {
         return fn(new Error('cannot find user'));
     } else {
         return fn(null, user);
     }
     connection.end();
 }
这是我的回拨功能

app.post('/Login', function(req, res) {
    Authenticate(req.body.username, req.body.password, function(err, user) {
        if (user) {
            req.session.regenerate(function() {
                req.session.user = user;
                req.session.success = 'Authenticated as ' + user;
                res.redirect('Home');
            });
        } else {
            req.session.error = 'Authentication failed, please check your username and password.';
            res.redirect('Login');
        }
    });
})
我犯了一个错误,我无法理解

TypeError: Cannot set property 'error' of undefined
    at /...../.../node_modules/app.js:42:23
    at Authenticate (/..../..../node_modules/app.js:82:11).

请分享你的想法

取出else,查看是否有任何其他req.session功能正常,如果没有,请检查是否为express validator正确配置了中间件

似乎是说req.session不存在于此行中:req.session.error='身份验证失败,请检查您的用户名和密码';谢谢我不太明白。但我试着评论成功和错误会话消息,但仍然得到相同的错误。也许req.session根本不存在。您的错误告诉我的唯一一件事是req.session未定义。就您的代码而言,它看起来不错。是的,正确。谢谢,我已经删除了整个会话的详细信息,它现在正在工作。身份验证仍然不起作用。但是我想这和我的DB.NP有关,我把它作为答案,你可以结束这个问题。