我正在尝试使用node.js设置用户级身份验证,所以我进行了npm install -g jsonwebtoken --save。然而,当我使用require('jsonwebtoken');并尝试编译我的代码时,它会给出标题中描述的错误。现在,由于某种原因,当我卸载JWT并尝试在没有它的情况下运行我的代码时,它可以编译,但显然无法正常工作。我尝试重新安装它,但仍然没有成功。
我的npm版本是6.3.0
我的node版本是v11.1.0
安装命令为:npm install -g jsonwebtoken --save
代码:
'use strict';
require('jsonwebtoken');
exports.generateToken = async (data) => {
return jwt.sign(data, global.SALT_KEY, { expiresIn: '1d' });
}
exports.decodeToken = async (token) => {
var data = await jwt.verify(token, global.SALT_KEY);
return data;
}
exports.authorize = function (req, res, next) {
var token = req.body.token || req.query.token || req.headers['x-access-token'];
if (!token) {
res.status(401).json({
message: 'Acesso Restrito'
});
} else {
jwt.verify(token, global.SALT_KEY, function (error, decoded) {
if (error) {
res.status(401).json({
message: 'Token Inválido'
});
} else {
next();
}
});
}
};
exports.isAdmin = function (req, res, next) {
var token = req.body.token || req.query.token || req.headers['x-access-token'];
if (!token) {
res.status(401).json({
message: 'Token Inválido'
});
} else {
jwt.verify(token, global.SALT_KEY, function (error, decoded) {
if (error) {
res.status(401).json({
message: 'Token Inválido'
});
} else {
if (decoded.roles.includes('admin')) {
next();
} else {
res.status(403).json({
message: 'Esta funcionalidade é restrita para administradores'
});
}
}
});
}
};
const jwt = require('jsonwebtoken');
- Chance