Vue权限控制addRoutes

说到Vue权限控制,你可能会第一个想到

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
/**
* Created by superman on 17/2/16.
* http配置
*/

import axios from 'axios'
import store from './store/store'
import * as types from './store/types'
import router from './router'

// axios 配置
axios.defaults.timeout = 5000;
axios.defaults.baseURL = 'https://api.github.com';

// http request 拦截器
axios.interceptors.request.use(
config => {
if (store.state.token) {
config.headers.Authorization = `token ${store.state.token}`;
}
return config;
},
err => {
return Promise.reject(err);
});

// http response 拦截器
axios.interceptors.response.use(
response => {
return response;
},
error => {
if (error.response) {
switch (error.response.status) {
case 401:
// 401 清除token信息并跳转到登录页面
store.commit(types.LOGOUT);
router.replace({
path: 'login',
query: {redirect: router.currentRoute.fullPath}
})
}
}
// console.log(JSON.stringify(error));//console : Error: Request failed with status code 402
return Promise.reject(error.response.data)
});

export default axios;

VueRouter

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
const router = new VueRouter({
routes
})

router.beforeEach((to, from, next) => {
if (to.path == '/login') {
//清除token
...
}
let token = get('token'); //获取token
if (!token && to.path != '/login') {
next({ path: '/login' })
} else {
next()
}
})

但上面的只能对登录拦截,跳转拦截,不能控制user权限,最好的方式是动态注入路由addRoutes

1
2
3
4
import router from './router'
router.addRoutes(routes)
或者
this.$router.addRoutes(routers)