为什么 res.json() 返回 null?
2022-03-15
374
我正在尝试使用 jwt 编写我的 React 应用的身份验证部分。我的 App.js 文件中不断出现此错误:“未捕获(在承诺中)TypeError:无法读取 null 的属性(读取“错误”)”,这让我发现当访问某个路由时,应该返回一些有关用户的数据,但响应主体实际上是空的。这些是我的一些代码片段,我认为问题可能出在这里。任何帮助都将不胜感激,提前致谢!此外,如果我应该提供其他代码片段,请告诉我
这是来自我的 App.js 文件
const [authState, setAuthState] = useState({
username: "",
id: 0,
status: false,
});
useEffect(() => {
axios
.get("http://localhost:3001/users/auth", {
headers: {
accessToken: localStorage.getItem("accessToken"),
},
})
.then((response) => {
if (response.data.error) { //this is where the error appears
setAuthState({ ...authState, status: false });
} else {
setAuthState({
username: response.data.username, //if I comment the line where the error appears, I get the same error here and on the line below, but with 'username' and 'id' instead of 'error'
id: response.data.id,
status: true,
});
}
});
}, []);
这是 res.json 没有返回任何内容的地方
router.get('/auth', validateToken, (req, res) => {
res.json(req.user);
});
这是validateToken 中间件
const { verify } = require('jsonwebtoken');
const validateToken = (req, res, next) => {
const accessToken = req.header("accessToken");
if (!accessToken) return res.json({ error: "User not logged in!" })
try {
const validToken = verify(accessToken, "importantsecret");
req.user = validToken; //we can access the username and id
if (validToken) {
return next();
}
} catch (err) {
return res.json({ error: err });
}
};
module.exports = { validateToken };
2个回答
好的,因此在您的中间件函数中,在此特定行中,
const validToken = verify(accessToken, "importantsecret");
req.user = validToken; //we can access the username and id
if (validToken) {
return next();
}
在这里,您正在创建一个名为“validToken”的常量变量并将 req.user 设置为它。然后,您正在检查它是否存在,然后运行 ​​next(),但如果 validToken 为 null/未定义怎么办?next() 永远不会运行!
YTGS
2022-03-15
可能是因为您实际上没有返回您的响应。
试试这个。
router.get('/auth',validateToken,(req,res)=>{return res.json(req.user);});
tykhan
2022-03-15