permission.js 870 B

123456789101112131415161718192021222324252627282930313233343536373839
  1. import { getToken } from '@/utils/auth'
  2. // 登录页面
  3. const loginPage = "/pages/login"
  4. // 页面白名单
  5. const whiteList = [
  6. '/pages/login', '/pages/register', '/pages/common/webview/index'
  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. if (getToken()) {
  19. if (to.url === loginPage) {
  20. uni.reLaunch({ url: "/" })
  21. }
  22. return true
  23. } else {
  24. if (checkWhite(to.url)) {
  25. return true
  26. }
  27. uni.reLaunch({ url: loginPage })
  28. return false
  29. }
  30. },
  31. fail(err) {
  32. console.log(err)
  33. }
  34. })
  35. })