首页 > 编程 > JavaScript > 正文

vue 权限认证token的实现方法

2019-11-19 13:28:36
字体:
来源:转载
供稿:网友

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

主要呢是分两步:

一是vue路由层的控制,由于项目的路由有规律可循,所以没有采用网上requireAuth那种在需要加验证的路由上配置meta(具体见:https://www.VeVB.COm/article/143928.htm)

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);});

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表