步骤1
在router/index.js中创建router实例
import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router)
// 公共路由
export const constantRoutes = [...]
// 防止连续点击多次路由报错
let routerPush = Router.prototype.push
Router.prototype.push = function push(location) {
return routerPush.call(this, location).catch(err => err)
}
// 创建路由
export default new Router({
mode: 'history', // 去掉url中的#
base: process.env.VUE_APP_WEB_BASE,
scrollBehavior: () => ({ y: 0 }),
routes: constantRoutes
})
步骤2
在src/permission.js中设置白名单,将目标页面的路径放入白名单列表(whiteList)中
import router from './router'
import store from './store'
import { Message } from 'element-ui'
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'
import { getToken } from '@/utils/auth'
import { isRelogin } from '@/utils/request'
NProgress.configure({ showSpinner: false })
const whiteList = ['/login', '/auth-redirect', '/bind', '/register', '/targetUrl']
router.beforeEach((to, from, next) => {
NProgress.start()
const token = localStorage.getItem('token')
if (getToken() || token) {
to.meta.title && store.dispatch('settings/setTitle', to.meta.title)
/* has token*/
if (to.path === '/login') {
next({ path: '/index' })
NProgress.done()
} else {
if (store.getters.roles.length === 0) {
isRelogin.show = true
// 判断当前用户是否已拉取完user_info信息
store.dispatch('GetInfo').then(() => {
isRelogin.show = false
store.dispatch('GenerateRoutes').then(accessRoutes => {
// 根据roles权限生成可访问的路由表
router.addRoutes(accessRoutes) // 动态添加可访问路由表
next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
})
}).catch(err => {
store.dispatch('LogOut').then(() => {
Message.error(err)
next({ path: '/' })
})
})
} else {
next()
}
}
} else {
// 没有token
if (whiteList.indexOf(to.path) !== -1) {
// 在免登录白名单,直接进入
next()
} else {
next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
NProgress.done()
}
}
// next()
// NProgress.done()
})
router.afterEach(() => {
NProgress.done()
})
注:这一步已经实现免密访问页面了,但是页面中的接口请求需要token的话,还需要额外配置
步骤3
在页面加载时直接调用登录接口获取token值(这个方法很不好,但是时间有限只能这么做了,如果大家有更好的方法欢迎提出🥰)
src/main.js(这部分代码可以写在需要访问的页面文件中)
new Vue({
el: '#app',
router,
i18n,
store,
render: h => h(App),
mounted() {
this.getToken();
},
methods: {
getToken() {
axios
.post('/loginUrl', {
username: 'Lily',
password: '123456',
})
.then(response => {
const token = response.data.data.access_token
// 将token值存储在浏览器的本地存储中
localStorage.setItem('token', token)
})
.catch(error => {
console.error('获取token失败:', error)
})
},
}
})
步骤四
request.js
const token = localStorage.getItem('token')
if (token && !isToken || getToken()) {
let lang = localStorage.getItem('lang')
if (!lang) {
lang = 'zh'
}
if (window.self !== window.top) {
config.headers['fromSource'] = 'iframe'
}
config.headers['lang'] = lang
config.headers['Authorization'] = token ? 'Bearer ' + token : 'Bearer' + getToken() // 让每个请求携带自定义token 请根据实际情况自行修改
}
现在所有的接口请求时都会有token值了