permission.js 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. import router from './router'
  2. import store from './store'
  3. import NProgress from 'nprogress' // progress bar
  4. import 'nprogress/nprogress.css' // progress bar style
  5. // import { getToken } from '@/utils/auth' // get token from cookie
  6. NProgress.configure({ showSpinner: false }) // NProgress Configuration
  7. const whiteList = ['/login',] // no redirect whitelist
  8. router.beforeEach(async(to, from, next) => {
  9. // start progress bar
  10. NProgress.start()
  11. // set page title
  12. // determine whether the user has logged in
  13. // const hasToken = getToken()
  14. const hasToken = store.getters.token
  15. if (hasToken) {
  16. if (to.path === '/login') {
  17. // if is logged in, redirect to the home page
  18. next({ path: '/' })
  19. NProgress.done()
  20. } else {
  21. const userinfo = store.getters.userinfo && Object.keys(store.getters.userinfo).length > 0
  22. console.log('store.getters', store.getters)
  23. console.log('userinfo', userinfo)
  24. // console.log('to', {...to} )
  25. if (userinfo) {
  26. next()
  27. } else {
  28. try {
  29. // 获取用户信息
  30. const data = await store.dispatch('user/getInfo')
  31. await store.commit('user/SET_USERINFO', data)
  32. next({ ...to, replace: true })
  33. } catch (error) {
  34. // remove token and go to login page to re-login
  35. // await store.dispatch('user/resetToken')
  36. // Notify({ type: 'danger', message: error || '发生异常' })
  37. next(`/login?redirect=${to.path}`)
  38. NProgress.done()
  39. }
  40. }
  41. }
  42. } else {
  43. // next()
  44. /* has no token*/
  45. if (whiteList.indexOf(to.path) !== -1) {
  46. // in the free login whitelist, go directly
  47. next()
  48. } else {
  49. // // other pages that do not have permission to access are redirected to the login page.
  50. next(`/login?redirect=${to.path}`)
  51. NProgress.done()
  52. }
  53. }
  54. })
  55. router.afterEach(() => {
  56. // finish progress bar
  57. NProgress.done()
  58. })