我正在登录/注册系统上实施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]))刚刚返回定义?
答案 0 :(得分:1)
您没有正确发送回复。
res.json([id]);
它只是发送array of id
。这就是res.data.token
未定义的原因。因为data
不包含对象。
发送适当的对象,如:
res.json({id});