• vue3后台管理系统之路由守卫


    下载进度条

    pnpm install nprogress

    1. //路由鉴权:鉴权,项目当中路由能不能被的权限的设置(某一个路由什么条件下可以访问、什么条件下不可以访问)
    2. import router from '@/router'
    3. import setting from './setting'
    4. // eslint-disable-next-line @typescript-eslint/ban-ts-comment
    5. //@ts-expect-error
    6. import nprogress from 'nprogress'
    7. //引入进度条样式
    8. import 'nprogress/nprogress.css'
    9. nprogress.configure({ showSpinner: false })
    10. //获取用户相关的小仓库内部token数据,去判断用户是否登录成功
    11. import useUserStore from './store/modules/user'
    12. import pinia from './store'
    13. const userStore = useUserStore(pinia)
    14. //全局守卫:项目当中任意路由切换都会触发的钩子
    15. //全局前置守卫
    16. // eslint-disable-next-line @typescript-eslint/ban-ts-comment
    17. //@ts-expect-error
    18. router.beforeEach(async (to: any, from: any, next: any) => {
    19. document.title = `${setting.title} - ${to.meta.title}`
    20. //to:你将要访问那个路由
    21. //from:你从来个路由而来
    22. //next:路由的放行函数
    23. nprogress.start()
    24. //获取token,去判断用户登录、还是未登录
    25. const token = userStore.token
    26. //获取用户名字
    27. const username = userStore.username
    28. //用户登录判断
    29. if (token) {
    30. //登录成功,访问login,不能访问,指向首页
    31. if (to.path == '/login') {
    32. next({ path: '/' })
    33. } else {
    34. //登录成功访问其余六个路由(登录排除)
    35. //有用户信息
    36. if (username) {
    37. //放行
    38. next()
    39. } else {
    40. //如果没有用户信息,在守卫这里发请求获取到了用户信息再放行
    41. try {
    42. //获取用户信息
    43. await userStore.userInfo()
    44. //放行
    45. //万一:刷新的时候是异步路由,有可能获取到用户信息、异步路由还没有加载完毕,出现空白的效果
    46. next({ ...to })
    47. // eslint-disable-next-line unicorn/prefer-optional-catch-binding
    48. } catch (error) {
    49. //token过期:获取不到用户信息了
    50. //用户手动修改本地存储token
    51. //退出登录->用户相关的数据清空
    52. await userStore.userLogout()
    53. next({ path: '/login', query: { redirect: to.path } })
    54. }
    55. }
    56. }
    57. } else {
    58. //用户未登录判断
    59. if (to.path == '/login') {
    60. next()
    61. } else {
    62. next({ path: '/login', query: { redirect: to.path } })
    63. }
    64. }
    65. })
    66. //全局后置守卫
    67. router.afterEach(() => {
    68. nprogress.done()
    69. })
    70. //第一个问题:任意路由切换实现进度条业务 ---nprogress
    71. //第二个问题:路由鉴权(路由组件访问权限的设置)
    72. //全部路由组件:登录|404|任意路由|首页|数据大屏|权限管理(三个子路由)|商品管理(四个子路由)
    73. //用户未登录:可以访问login,其余六个路由不能访问(指向login)
    74. //用户登录成功:不可以访问login[指向首页],其余的路由可以访问

    pnpm run build

  • 相关阅读:
    docker-compose内网本地安装
    spark(day04)
    软件测试 - postman高级使用
    哪款pdf转换软件好用?这个超好用!
    2015年经过官方去噪的NPP/VIIRS数据
    FreeSWITCH rtp 统计
    x程无忧sign逆向分析
    导入网络下载的虚拟机无法获取IP实战
    First, rewinding head to replay your work on top of it...
    RabbitMQ系列【14】备份交换机
  • 原文地址:https://blog.csdn.net/m0_52704461/article/details/133956455