基于vue 实现token验证的实例代码


Posted in Javascript onDecember 14, 2017

vue-koa2-token

基于vue的 做了token验证

前端部分(对axios设置Authorization)

import axios from 'axios'
import store from '../store'
import router from '../router'
//设置全局axios默认值
axios.defaults.timeout = 6000; //6000的超时验证
axios.defaults.headers.post['Content-Type'] = 'application/json;charset=UTF-8';
//创建一个axios实例
const instance = axios.create();
instance.defaults.headers.post['Content-Type'] = 'application/json;charset=UTF-8';
axios.interceptors.request.use = instance.interceptors.request.use;
//request拦截器
instance.interceptors.request.use(
  config => {
    //每次发送请求之前检测都vuex存有token,那么都要放在请求头发送给服务器
    if(store.state.token){
      config.headers.Authorization = `token ${store.state.token}`;
    }
    return config;
  },
  err => {
    return Promise.reject(err);
  }
);
//respone拦截器
instance.interceptors.response.use(
  response => {
    return response;
  },
  error => { //默认除了2XX之外的都是错误的,就会走这里
    if(error.response){
      switch(error.response.status){
        case 401:
          store.dispatch('UserLogout'); //可能是token过期,清除它
          router.replace({ //跳转到登录页面
            path: 'login',
            query: { redirect: router.currentRoute.fullPath } // 将跳转的路由path作为参数,登录成功后跳转到该路由
          });
      }
    }
    return Promise.reject(error.response);
  }
);
export default instance;

 然后在路由文件中

//注册全局钩子用来拦截导航
router.beforeEach((to, from, next) => {
 //获取store里面的token
 let token = store.state.token;
 //判断要去的路由有没有requiresAuth
 if(to.meta.requiresAuth){
  if(token){
   next();
  }else{
   next({
    path: '/login',
    query: { redirect: to.fullPath } // 将刚刚要去的路由path(却无权限)作为参数,方便登录成功后直接跳转到该路由
   });
  }
 }else{
  next();//如果无需token,那么随它去吧
 }
});

后端(node) 我们封装了一个中间件 在需要验证token的路由,加上这个中间件

router.get('/dosh',checkToken,User.dosh)
const jwt = require('jsonwebtoken');

1、使用jsonwebtoken 创建token

const jwt = require('jsonwebtoken');
//登录时:核对用户名和密码成功后,应用将用户的id(图中的user_id)作为JWT Payload的一个属性
module.exports = function(user_id){
  const token = jwt.sign({
    user_id: user_id
  }, 'sinner77', {
    expiresIn: '3600s' //过期时间设置为60妙。那么decode这个token的时候得到的过期时间为 : 创建token的时间 + 设置的值
  });
  return token;
};

2、对于前端的请求,校验接口

//检查token是否过期
module.exports = async ( ctx, next ) => {
  if(ctx.request.header['authorization']){
    let token = ctx.request.header['authorization'].split(' ')[1];
    //解码token
    let decoded = jwt.decode(token, 'sinner77');
    //console.log(decoded);的输出 :{ user_id: '123123123', iat: 1494405235, exp: 1494405235 }
    if(token && decoded.exp <= new Date()/1000){
      ctx.status = 401;
      ctx.body = {
        message: 'token过期'
      };
    }else{
      //如果权限没问题,那么交个下一个控制器处理
      return next();
    }
  }else{
    ctx.status = 401;
    ctx.body = {
      message: '没有token'
    }
  }
};

代码托管github 欢迎star

https://github.com/yxl720/vue-koa2-token

总结

以上所述是小编给大家介绍的基于vue 实现token验证的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js实现广告漂浮效果的小例子
Jul 02 Javascript
jquery得到iframe src属性值的方法
Sep 25 Javascript
localResizeIMG先压缩后使用ajax无刷新上传(移动端)
Aug 11 Javascript
jQuery操作属性和样式详解
Apr 13 Javascript
第一次接触神奇的Bootstrap网格系统
Jul 27 Javascript
vue-router路由参数刷新消失的问题解决方法
Jun 17 Javascript
使用vue-cli导入Element UI组件的方法
May 16 Javascript
深入理解Vue 组件之间传值
Aug 16 Javascript
使用layui 渲染table数据表格的实例代码
Aug 19 Javascript
jquery实现联想词搜索框和搜索结果分页的示例
Oct 10 jQuery
JS实现换肤功能的方法实例详解
Jan 30 Javascript
一些你可能不熟悉的JS知识点总结
Mar 15 Javascript
JavaScript实现左侧菜单效果
Dec 14 #Javascript
JavaScript实现全选取消效果
Dec 14 #Javascript
vue.js中引入vuex储存接口数据及调用的详细流程
Dec 14 #Javascript
javascript实现数字配对游戏的实例讲解
Dec 14 #Javascript
form表单数据封装成json格式并提交给服务器的实现方法
Dec 14 #Javascript
JavaScript 数组去重并统计重复元素出现的次数实例
Dec 14 #Javascript
vue项目中的webpack-dev-sever配置方法
Dec 14 #Javascript
You might like
PHILIPS L4X25T电路分析和打理
2021/03/02 无线电
使用VisualStudio开发php的图文设置方法
2010/08/21 PHP
PHP中使用socket方式GET、POST数据实例
2015/04/02 PHP
Zend Framework路由器用法实例详解
2016/12/11 PHP
tp5框架的增删改查操作示例
2019/10/31 PHP
js 判断浏览器类型 去全角、半角空格 自动关闭当前窗口
2009/04/10 Javascript
基于jQuery的图片大小自动适应实现代码
2010/11/17 Javascript
jQuery UI Dialog控件中的表单无法正常提交的解决方法
2010/12/19 Javascript
改进UCHOME的记录发布,增强可访问性用户体验
2011/01/17 Javascript
Javascript计算时间差的函数分享
2011/07/04 Javascript
js获取 type=radio 值的方法
2014/05/09 Javascript
利用jquery操作Radio方法小结
2014/10/20 Javascript
详解javascript的变量与标识符
2016/01/04 Javascript
全面解析Bootstrap中Carousel轮播的使用方法
2016/06/13 Javascript
bootstrap table实现单击单元格可编辑功能
2017/03/28 Javascript
vue两个组件间值的传递或修改方式
2018/07/04 Javascript
JS获取浏览器地址栏的多个参数值的任意值实例代码
2018/07/24 Javascript
JavaScript在web自动化测试中的作用示例详解
2019/08/25 Javascript
如何运行Python程序的方法
2013/04/21 Python
详解python3中socket套接字的编码问题解决
2017/07/01 Python
在python 不同时区之间的差值与转换方法
2019/01/14 Python
Python多叉树的构造及取出节点数据(treelib)的方法
2019/08/09 Python
Python 脚本拉取 Docker 镜像问题
2019/11/10 Python
python如何实现单链表的反转
2020/02/10 Python
Python request中文乱码问题解决方案
2020/09/17 Python
凯特·丝蓓英国官网:Kate Spade英国
2016/11/07 全球购物
一套比较完整的软件测试人员面试题
2012/05/13 面试题
服装销售人员求职自我评价
2013/09/26 职场文书
安踏广告词改编版
2014/03/21 职场文书
高一学生评语大全
2014/04/25 职场文书
红领巾心向党演讲稿
2014/09/10 职场文书
单位工资证明范本
2015/06/12 职场文书
教师外出学习心得体会
2016/01/18 职场文书
Win11快速关闭所有广告推荐
2022/04/19 数码科技
Win11显卡控制面板打开显卡设置方法
2022/04/20 数码科技
MySQL 执行数据库更新update操作的时候数据库卡死了
2022/05/02 MySQL