0
点赞
收藏
分享

微信扫一扫

173-ruoyi-cloud整合cas-server5.3(1)-前端修改

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();
      }
    }
举报

相关推荐

0 条评论