【发布时间】:2021-07-29 18:07:16
【问题描述】:
我们在 getpost 路由器中有 authenticateToken 中间件。 authenticateToken 中间件验证令牌。
如果令牌已过期,则执行 if(err) 条件语句。这时候通过refreshtoken再次发出accessToken。
我想将这个发出的 accessToken 传递给路由器。 console.log(accessToken);如何修复代码来执行此操作?
这是我的代码
(index.js)
router.post('/getpost', authenticateToken, async (req, res, next) => {
try {
console.log(accessToken);
} catch (error) {
console.error(error);
next(error); // status 500
}
});
(中间件.js)
exports.authenticateToken = (req, res, next) => {
jwt.verify(token, process.env.ACCESS_TOKEN_SECRET, async (err, user) => {
if (err) {
jwt.verify(
refreshToken,
process.env.REFRESH_TOKEN_SECRET,
async (err, user) => {
if (err) return res.sendStatus(403);
const accessToken = await generateAccessToken(users); // i want to pass this accessToken to router
console.log('accessToken::::', accessToken);
},
);
res.json({accessToken: accessToken});
}
req.user = user;
next();
});
};
function generateAccessToken(user) {
return jwt.sign(user, process.env.ACCESS_TOKEN_SECRET, {expiresIn: '55s'});
}
app.post("/token", (req, res) => {
const refreshToken = req.body.token;
console.log("refreshToken:", refreshToken);
if (refreshToken == null) return res.sendStatus(401);
if (!refreshTokens.includes(refreshToken)) return res.sendStatus(403);
jwt.verify(refreshToken, process.env.REFRESH_TOKEN_SECRET, (err, user) => {
if (err) return res.sendStatus(403);
const accessToken = generateAccessToken({ name: user.name });
res.json({ accessToken: accessToken });
});
});
【问题讨论】:
-
你能用你更新的本地代码更新有问题的代码吗,所以我可以帮助你解决你尝试过的问题
标签: javascript node.js reactjs react-native jwt