首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >vue+express生成token

vue+express生成token

作者头像
江一铭
发布2022-06-18 10:37:31
发布2022-06-18 10:37:31
1.2K0
举报
文章被收录于专栏:技术社区技术社区

在使用vue+node开发的过程中,在写登录时候我们会使用到token验证,下面我来分享一下express生成token和简单的使用,希望对你有所帮助。

安装

代码语言:javascript
复制
npm install express-jwt
npm install jsonwebtoken --save

express-jwt内部引用了jsonwebtoken,对其封装使用。在实际的项目中这两个都需要引用,他们两个的定位不一样。 jsonwebtoken是用来生成token给客户端的,express-jwt是用来验证token的。

新建token.js文件

代码语言:javascript
复制
//用于生成和解析token
var jwt = require('jsonwebtoken');
var signkey = 'zxcvbnmpoiuy';//自定义秘钥

exports.setToken = function (phone, pasaWord) {
    return new Promise((resolve, reject) => {
        const rule = {
            phone: phone,
            pasaWord: pasaWord
        }
        // rule 账号密码 expiresIn 失效时间
        const token = jwt.sign(rule, signkey, { expiresIn: '1h' });
        resolve(token);
    })
}

exports.verToken = function (token) {
    return new Promise((resolve, reject) => {
        var info = jwt.verify(token.split(' ')[1], signkey);
        resolve(info);
    })
}

app.js中配置

代码语言:javascript
复制
var vertoken = require('./utils/token');
var expressJWT = require('express-jwt');

app.use(function (req, res, next) {
// x-access-token  前端传过来的token
  var token = req.headers['x-access-token'];
  if (token == undefined) {
    return next();
  } else {
    vertoken.verToken(token).then((data) => {
      req.data = data;
      return next();
    }).catch((error) => {
      return next();
    })
  }
  next(createError(404));
});


//验证token
app.use(expressJWT({
  secret: 'zxcvbnmpoiuy', // signkey 自定义秘钥 需跟上方保持一致
  algorithms: ["HS256"]
}).unless({
  path: ['/users/addUsers', "/users/login"]//除了这些地址,其他的URL都需要验证
}));


app.use(function (err, req, res, next) {
  // set locals, only providing error in development
  if (err.status == 401) {
    return res.status(401).send({
      code: 401,
      msg: "token失效",
      success: false,
    });
  }
  res.locals.message = err.message;
  res.locals.error = req.app.get('env') === 'development' ? err : {};

  // render the error page
  // res.status(err.status || 500);
  // res.render('error');
});

在接口中使用

代码语言:javascript
复制
// token 验证
var jwt = require('jsonwebtoken');
var Ctoken = require('../utils/token');

router.post('/login', async function (req, res, next) {
  let bady = {
    phone: req.body.phone,
    passWord: req.body.passWord,
  }
  //登录前查询数据库有无此账号
  const data = await User.find().where({
    phone: req.body.phone
  })
  if (data.length == 0) {
    res.send({
      code: 500,
      success: false,
      msg: "该用户没有注册。请先前往注册"
    })
    return
  }
  // 验证密码
  if (data.length != 0 && data[0].passWord !== req.body.passWord) {
    res.send({
      code: 500,
      success: false,
      msg: "密码错误,请重新验证"
    })
    return
  }

  Ctoken.setToken(bady).then((data) => {
    let CObj = {
      code: 200,
      msg: "登录成功",
      token: data
    }
    res.json(CObj);
  });
})

错误: expressjwt is not a function 版本太高。 只需要将pakage.json中的express-jwt版本改为6.1.1,重新npm i 即可使用。 express-jwt新特性请自行前往npm官网查看。

algorithms should be set 在app.use(expressJWT) 这个配置中添加 algorithms: [“HS256”];

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-06-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档