route.ts 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /**
  2. * by 菲鸽 on 2024-03-06
  3. * 路由拦截,通常也是登录拦截
  4. * 可以设置路由白名单,或者黑名单,看业务需要选哪一个
  5. * 我这里应为大部分都可以随便进入,所以使用黑名单
  6. */
  7. import { useUserStore } from '@/store'
  8. import { getNeedLoginPages, needLoginPages as _needLoginPages } from '@/utils'
  9. // TODO Check
  10. const loginRoute = '/pages/login/index'
  11. const isLogined = () => {
  12. const userStore = useUserStore()
  13. return userStore.isLogined
  14. }
  15. const isDev = import.meta.env.DEV
  16. // 黑名单登录拦截器 - (适用于大部分页面不需要登录,少部分页面需要登录)
  17. const navigateToInterceptor = {
  18. // 注意,这里的url是 '/' 开头的,如 '/pages/index/index',跟 'pages.json' 里面的 path 不同
  19. invoke({ url }: { url: string }) {
  20. // console.log(url) // /pages/route-interceptor/index?name=feige&age=30
  21. const path = url.split('?')[0]
  22. let needLoginPages: string[] = []
  23. // 为了防止开发时出现BUG,这里每次都获取一下。生产环境可以移到函数外,性能更好
  24. if (isDev) {
  25. needLoginPages = getNeedLoginPages()
  26. } else {
  27. needLoginPages = _needLoginPages
  28. }
  29. const isNeedLogin = needLoginPages.includes(path)
  30. if (!isNeedLogin) {
  31. return true
  32. }
  33. const hasLogin = isLogined()
  34. if (hasLogin) {
  35. return true
  36. }
  37. const redirectRoute = `${loginRoute}?redirect=${encodeURIComponent(url)}`
  38. uni.navigateTo({ url: redirectRoute })
  39. return false
  40. },
  41. }
  42. export const routeInterceptor = {
  43. install() {
  44. uni.addInterceptor('navigateTo', navigateToInterceptor)
  45. uni.addInterceptor('reLaunch', navigateToInterceptor)
  46. uni.addInterceptor('redirectTo', navigateToInterceptor)
  47. },
  48. }