permission.js 1.2 KB

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