permission - 副本.js 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. import { getToken,isLoginSso,removeToken,getSsoAdminToken } from '@/utils/auth'
  2. // 登录页面
  3. const loginPage = "/pages/login"
  4. // 页面白名单
  5. const whiteList = [
  6. '/pages/login', '/pages/register', '/pages/common/webview/index', '/pages/loginSso',
  7. ]
  8. // 检查地址白名单
  9. function checkWhite(url) {
  10. const path = url.split('?')[0]
  11. return whiteList.indexOf(path) !== -1
  12. }
  13. // 页面跳转验证拦截器
  14. let list = ["navigateTo", "redirectTo", "reLaunch", "switchTab"]
  15. list.forEach(item => {
  16. uni.addInterceptor(item, {
  17. invoke(to) {
  18. console.log(isLoginSso,'isLoginSso')
  19. // 启用单点登录后没有ssoToken清除当前token
  20. if (!getSsoAdminToken() && isLoginSso) {
  21. removeToken()
  22. };
  23. if (getToken()) {
  24. if (to.url === loginPage) {
  25. uni.reLaunch({ url: "/" })
  26. }
  27. return true
  28. } else if(isLoginSso){
  29. console.log(777)
  30. uni.reLaunch({ url: '/pages/loginSso'})
  31. return false
  32. }else {
  33. if (checkWhite(to.url)) {
  34. console.log(6666)
  35. return true
  36. }
  37. console.log(8888)
  38. uni.reLaunch({ url: loginPage })
  39. return false
  40. }
  41. },
  42. fail(err) {
  43. console.log(err)
  44. }
  45. })
  46. })