当前位置: 代码网 > it编程>编程语言>Javascript > vue+express生成token方式

vue+express生成token方式

2024年09月08日 Javascript 我要评论
vue+express生成token在使用vue+node开发的过程中,在写登录时候我们会使用到token验证,下面我来分享一下express生成token和简单的使用安装npm install ex

vue+express生成token

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

安装

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

新建token.js文件

//用于生成和解析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中配置

var vertoken = require('./utils/token');
var expressjwt = require('express-jwt');

// 解析token获取用户信息
app.use(function (req, res, next) {
// authorization 必须为这个  和前端保持一致
  var token = req.headers['authorization'];

  if (token == undefined) {
    return next();
  } else {
    vertoken.vertoken(token).then((data) => {
      req.data = data;
      return next();
    }).catch((error) => {
      return next();
    })
  }
});


//验证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
  res.locals.message = err.message
  res.locals.error = req.app.get('env') === 'development' ? err : {}
  // render the error page
  res.status(err.status || 500)

  if (err.status == 401) {
    res.send(httprequest.untoken())
  } else if (err.status == 404) {
    res.send(httprequest.notfound())
  } else {
    res.send({ code: err.status, data: {}, msg: err.status })
  }
})

在接口中使用

// 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”];

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com