Не могу войти с помощью экспресс + mysql, регистрация работает - PullRequest
0 голосов
/ 16 октября 2019

Я пробовал разные способы заставить его работать, но я не могу заставить работать страницу входа в систему, и проблема, на мой взгляд, связана с экспресс-поддержкой.

//index.js
const  findUserByEmail  = (email, cb) => {
    return  mc.query('SELECT * FROM user_login WHERE email = ?',[email], (err, row) => {
            cb(err, row)
    });
}

router.post('/login', (req, res) => {
    const  email  =  req.body.email;
    const  password  =  req.body.password;

    findUserByEmail(email, (err, user)=>{
        if (err) return  res.status(500).send({ "message":  'Server error!', "status": '500'});
        if (!user) return  res.status(404).send({ "message":  'User not found!', "status": '404'});
        const  result  =  bcrypt.compareSync(password, user.password);
        if(!result) return res.status(401).send({ "message":  'Password not valid!', "status": '401'});
        const  expiresIn  =  24  *  60  *  60;
        const  accessToken  =  jwt.sign({ id:  user.id }, SECRET_KEY, {
            expiresIn:  expiresIn
        });
        res.status(200).send({ "user":  user, "access_token":  accessToken, "expires_in":  expiresIn, "message":  'Success!', "status": '200'});
    });
});

У меня работает регистр, но когда я пытаюсь вышеупомянутый код, с учетной записью в базе данных, он выдает эту ошибку в экспресс:

C:\JSProjects\IonicProjectV2\express-auth-demo2\node_modules\mysql\lib\protocol\Parser.js:437
      throw err; // Rethrow non-MySQL errors
      ^

Error: Illegal arguments: string, undefined
    at Object.bcrypt.compareSync (C:\JSProjects\IonicProjectV2\express-auth-demo2\node_modules\bcryptjs\dist\bcrypt.js:265:19)

1 Ответ

1 голос
/ 16 октября 2019

Пароль или user.password не определены, поэтому bcrypt жалуется на это.

Пожалуйста, добавьте console.logs вот так и посмотрите, какой из них не определен.

router.post('/login', (req, res) => {
    const email = req.body.email;
    const password = req.body.password;

    console.log(password);

    findUserByEmail(email, (err, user) => {
        if (err) return res.status(500).send({ "message": 'Server error!', "status": '500' });
        if (!user) return res.status(404).send({ "message": 'User not found!', "status": '404' });

        console.log(user);
        const result = bcrypt.compareSync(password, user[0].password);
        if (!result) return res.status(401).send({ "message": 'Password not valid!', "status": '401' });
        const expiresIn = 24 * 60 * 60;
        const accessToken = jwt.sign({ id: user.id }, SECRET_KEY, {
            expiresIn: expiresIn
        });
        res.status(200).send({ "user": user, "access_token": accessToken, "expires_in": expiresIn, "message": 'Success!', "status": '200' });
    });
});

Edit : пароль пользователя был внутри user [0] .password, поэтому использование этого в bcrypt.compareSync решило проблему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...