Emr*_*mre 4 node.js express jwt express-jwt
我想进行检查验证,但返回给我
JsonWebTokenError:必须提供秘密或公钥
我可以成功获取令牌
我怎样才能解决这个问题?
我正在遵循本教程;
https://www.youtube.com/watch?v=8Ip0pcwbWYM&t=633s
const jwt = require('jsonwebtoken');
module.exports = (req, res, next) => {
try {
const token = req.headers.authorization.split(" ")[1];
console.log(token);
const decoded = jwt.verify(token, process.env.JWT_KEY);
req.userData = decoded;
next();
} catch (error) {
console.log(error);
return res.status(401).json({
message: 'Auth failed'
})
}
}
Run Code Online (Sandbox Code Playgroud)
process.env全局变量由节点在运行时注入供您的应用程序使用。您需要创建一个新env文件来存储这些环境变量。
也就是说,您必须JWT_KEY在单独的 js 存档中声明变量。如果您使用 Nodemon,只需创建一个存档nodemon.json(在本例中与 env 类似)并声明您的变量,如下所示:
{
"env": {
"JWT_KEY": value,
...
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
25598 次 |
| 最近记录: |