当前位置: 移动技术网 > IT编程>脚本编程>vue.js > vue 权限认证token的实现方法

vue 权限认证token的实现方法

2018年08月06日  | 移动技术网IT编程  | 我要评论

024观赏鱼,智器x7,大营旅游度假村

最近搞一个vue的项目,接口带了权限验证,于是乎稍微研究了一下,中间遇到的各种坑都来源于自己概念的不熟悉。

主要呢是分两步:

一是vue路由层的控制,由于项目的路由有规律可循,所以没有采用网上requireauth那种在需要加验证的路由上配置meta(具体见:)

import vue from 'vue'
import router from 'vue-router'
vue.use(router)

const router = new router({...})

router.beforeeach((to, from, next) => {
 if(/^\/[s|b|v]/.test(to.path)){
  if (islogin()) {//判断token信息的自写方法
   next();
  }
  else {
   next({ name: 'login' })//跳转到登录页
  }
 }
 else {
  next();
 }
})

二是http 拦截器 ,统一处理所有http请求和响应,就得用上 axios 的拦截器。

import axios from 'axios'
// http request 拦截器
axios.interceptors.request.use(function (config) {
  config.headers.token = sessionstorage.getitem("user_token")//将接口返回的token信息配置到接口请求中
  return config;
}, function (error) {
  return promise.reject(error);
});
// http response 拦截器
axios.interceptors.response.use(function(response){
  if(response.data.code=='1001'||response.data.code=='1002'){//具体的判断token失效的参数
    sessionstorage.setitem("user_token",'')
    sessionstorage.setitem("loginuser",'{}')
    alert(response.data.msg);
    window.location.href='/#/login'//需求方要求一旦出错立即跳转登录,所以采取这种侵入式的手段。
  }else{
    return response
  }
}, function (error) {
  return promise.reject(error);
});

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网