jsonwebtoken生成token和解析

先上npm地址

jsonwebtoken:jsonwebtoken - npm

express-jwt:express-jwt - npmps

const express = require('express');
const jwt = require('jsonwebtoken');
const { expressjwt: expressJWT} = require('express-jwt')

const app = express();

// 设置密钥
const secretKey = 'my_secret_key';

// 生成Token
const token = jwt.sign({ username: 'user123' }, secretKey, { expiresIn: '1h' });

// 验证Token1(在req.auth里获取解析值)
app.use(expressJWT({ 
    secret: config.jwtSecretKey, 
    algorithms:["HS256"],
    credentialsRequired: false,
    getToken: function fromHeaderOrQuerystring(req) {
        if ( req.headers.authorization && req.headers.authorization.split(" ")[0] === "Bearer" ) {
            return req.headers.authorization.split(" ")[1];
        } else if (req.query && req.query.token) {
            return req.query.token;
        }
        return null;
    } 
}).unless({ path: ['/api/reguser','/api/login'] }))

//验证Token2
//(这里获取到的token值一定要是jwt生成的token,不能添加其他东西,否则会报incalid Token)
const router = express.Router()
function verifyToken(req, res, next) {
    const token = req.headers.authorization;
    
    if (!token) {
      return res.status(403).json({ code: -1, message: '请登录后再进行操作' });
    }
  
    jwt.verify(token, config.jwtSecretKey, (err, decoded) => {
      if (err) {
        return res.status(500).json({ code: -1, message: 'token验证失败'+err });
      }
  
      req.user = decoded;
      next();
    });
}
router.get('/userinfo',verifyToken, (req, res) => {
  res.send(`Welcome ${req.user.username}!`);
});)


// 启动服务器
app.listen(3000, () => {
  console.log('Server started on port 3000');
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值