undefined jwt token react / express

时间:2018-06-08 03:31:55

标签: express react-redux jwt

我正在登录/注册系统上实施JWT身份验证。当登录/注册成功时,我在localStorage中设置用户令牌。

问题是,当我检查localStorage时,用户密钥存在,但值未定义。我认为问题可能出在我的axios帖子或我的快递文件中,但我无法弄明白。

// my action creator
export function login(user, history) {
return async (dispatch) => {
  axios.post('/api/login', { user })
  .then(res => {
      dispatch({ type: AUTHENTICATED });
      localStorage.setItem('user', res.data.token);
      history.push('/');
  })
  .catch((error) => {
      dispatch({
          type: AUTHENTICATION_ERROR,
          payload: 'Invalid email or password'
      });
  });
 };
}

数据正确到达我的api。项目正在设置但值res.data.token未定义。下面是我的快递文件

// login.js (/api/login)
router.post('/', function(req, res) {
var email = req.body.user.email;
var password = req.body.user.password;
// TODO: create db file and import connection
var connection = mysql.createConnection({
    host: "localhost",
    user: "root",
    password: "",
    database: "dbname",
    port: 3307
});

connection.connect(function(err) {
    if(err) {
        console.log(err);
    } else {
        connection.query("SELECT ID, Password FROM Users WHERE Email = ?", [email], function(err, result) {
            if(err) {
                console.log('Could not find account');
                res.send(err);
            } else {

                var id = result[0].ID;

                bcrypt.compare(password, result[0].Password, function(err, result) {
                    if(result) {
                        console.log(id);
                        res.json({ id });
                    } else {
                        console.log('Incorrect password');
                    }
                });
            }
        });
      }
    });
});

由于我的动作创建者中的res.data.token返回undefined,这是否表示我的快速文件中的响应(res.json([id]))刚刚返回定义?

1 个答案:

答案 0 :(得分:1)

您没有正确发送回复。

res.json([id]);它只是发送array of id。这就是res.data.token未定义的原因。因为data不包含对象。

发送适当的对象,如:

res.json({id});