src/settings.js 新增:
cas: true //cas开启标志
src/store/modules/settings.js, 新增定义cas:
const state = {
cas:cas,
...
}
将该变量赋值为defaultSettings:
const { sideTheme, showSettings, topNav, tagsView, fixedHeader, sidebarLogo, dynamicTitle,cas } = defaultSettings
这样在就可以从setting中获取该变量了。
src/permission.js修改: 在router.beforeEach之前取cas:
var cas = store.state.settings.cas;
在已经登录的情况下,如获取用户登录信息异常时(可能登录信息过期等),退出登录:
if(cas==true){
store.dispatch('CasLogout').then(() => {})
}else{
store.dispatch('LogOut').then(() => {
Message.error(err)
next({ path: '/' })
})
}
在未登录时:
if(cas==true){
store.dispatch('CasLogin').then(res => {
// 拉取user_info
const roles = res.roles
store.dispatch('GenerateRoutes', { roles }).then(accessRoutes => {
// 根据roles权限生成可访问的路由表
router.addRoutes(accessRoutes) // 动态添加可访问路由表
next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
NProgress.done()
})
}).catch(err => {
console.log('------loginerr-----');
})
}else{
next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
NProgress.done()
}
src/permission.js完整代码:
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'
NProgress.configure({ showSpinner: false })
const whiteList = ['/login', '/auth-redirect', '/bind', '/register']
var cas = store.state.settings.cas;
router.beforeEach((to, from, next) => {
NProgress.start()
if (getToken()) {
to.meta.title && store.dispatch('settings/setTitle', to.meta.title)
/* has token*/
if (to.path === '/login') {
next({ path: '/' })
NProgress.done()
} else {
if (store.getters.roles.length === 0) {
// 判断当前用户是否已拉取完user_info信息
store.dispatch('GetInfo').then(() => {
store.dispatch('GenerateRoutes').then(accessRoutes => {
// 根据roles权限生成可访问的路由表
router.addRoutes(accessRoutes) // 动态添加可访问路由表
next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
})
}).catch(err => {
if(cas==true){
store.dispatch('CasLogout').then(() => {})
}else{
store.dispatch('LogOut').then(() => {
Message.error(err)
next({ path: '/' })
})
}
})
} else {
next()
}
}
} else {
// 没有token
if (whiteList.indexOf(to.path) !== -1) {
// 在免登录白名单,直接进入
next()
} else {
if(cas==true){
store.dispatch('CasLogin').then(res => {
// 拉取user_info
const roles = res.roles
store.dispatch('GenerateRoutes', { roles }).then(accessRoutes => {
// 根据roles权限生成可访问的路由表
router.addRoutes(accessRoutes) // 动态添加可访问路由表
next({ ...to, replace: true }) // hack方法 确保addRoutes已完成
NProgress.done()
})
}).catch(err => {
console.log('------loginerr-----');
})
}else{
next(`/login?redirect=${to.fullPath}`) // 否则全部重定向到登录页
NProgress.done()
}
}
}
})
router.afterEach(() => {
NProgress.done()
})
src/api/login.js,新增登录、退出接口:
export function casLogin() {
return request({
url: '/auth/casLogin',
method: 'get'
})
}
export function casLogout() {
return request({
url: '/auth/casLogout',
method: 'delete'
})
}
src/layout/components/Navbar.vue修改: computed中添加:
cas:{
get() {
return this.$store.state.settings.cas
}
}
logout()方法修改:
if(this.cas==true){
this.$store.dispatch('CasLogout').then(() => {})
}else{
this.$store.dispatch('LogOut').then(() => {
location.href = '/';
})
}
src/store/modules/user.js修改:
actions中添加:
CasLogin({ commit, state }) {
return new Promise((resolve, reject) => {
casLogin().then(res => {
setToken(res.token)
commit('SET_TOKEN', res.token)
const user = res.user
const avatar = user.avatar == "" ? require("@/assets/images/profile.jpg") : user.avatar;
if (res.roles && res.roles.length > 0) { // 验证返回的roles是否是一个非空数组
commit('SET_ROLES', res.roles)
commit('SET_PERMISSIONS', res.permissions)
} else {
commit('SET_ROLES', ['ROLE_DEFAULT'])
}
commit('SET_NAME', user.userName)
commit('SET_AVATAR', avatar)
resolve(res)
}).catch(error => {
reject(error)
})
})
},
CasLogout({ commit, state }) {
return new Promise((resolve, reject) => {
casLogout(state.token).then((res) => {
console.log("res",res)
commit('SET_TOKEN', '')
commit('SET_ROLES', [])
commit('SET_PERMISSIONS', [])
removeToken()
if(res.data){
location.href = res.data;
}
}).catch(error => {
reject(error)
})
})
},
src/utils/request.js修改:
修改service.interceptors.response中401的返回判断:
先获取cas变量:
var cas = store.state.settings.cas;
进行401\403的判断:
if (code === 401) {
if(cas==true){
window.location.replace(res.data.loginUrl)
}else{
MessageBox.confirm('登录状态已过期,您可以继续留在该页面,或者重新登录', '系统提示', {
confirmButtonText: '重新登录',
cancelButtonText: '取消',
type: 'warning'
}
).then(() => {
store.dispatch('LogOut').then(() => {
// location.href = '/index';
router.push("/login");
})
}).catch(() => {});
return Promise.reject('无效的会话,或者会话已过期,请重新登录。')
}
}else if(code === 403){
if(cas==true){
window.location.reload();
}
}