vue 权限认证token的实现方法
程序员文章站
2022-03-21 20:32:24
最近搞一个vue的项目,接口带了权限验证,于是乎稍微研究了一下,中间遇到的各种坑都来源于自己概念的不熟悉。
主要呢是分两步:
一是vue路由层的控制,由于项目的路由有规...
最近搞一个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); });
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: jqueryUI tab标签页代码分享
下一篇: C++雾中风景6:拷贝构造函数与赋值函数
推荐阅读
-
vue.js通过自定义指令实现数据拉取更新的实现方法
-
SpringMVC+ZTree实现树形菜单权限配置的方法
-
vue实现员工信息录入功能的方法
-
SpringBoot+Spring Security+JWT实现RESTful Api权限控制的方法
-
spring security动态配置url权限的2种实现方法
-
ASP.NET MVC使用ActionFilterAttribute实现权限限制的方法(附demo源码下载)
-
spring security动态配置url权限的2种实现方法
-
SpringBoot快速设置拦截器并实现权限验证的方法
-
SpringMVC+ZTree实现树形菜单权限配置的方法
-
ASP.NET MVC使用ActionFilterAttribute实现权限限制的方法(附demo源码下载)