最近搞一个vue的项目,接口带了权限验证,于是乎稍微研究了一下,中间遇到的各种坑都来源于自己概念的不熟悉。
主要呢是分两步:
一是vue路由层的控制,由于项目的路由有规律可循,所以没有采用网上requireAuth那种在需要加验证的路由上配置Meta(具体见:)
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 的拦截器。
rush:js;">
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);
});
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。
原文地址:https://www.jb51.cc/vue/31473.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。