模拟登陆 页面鉴权

用户模块逻辑示意图

路由总体示意图

image-20210130141625925

鉴权守卫逻辑示意图

image-20210130144001709

整体流程图

在这里插入图片描述

鉴权代码

//前置导航守卫
router.beforeResolve((to, from, next) => {
  // 每当导航切换时(包含刷新页面的第一次),该函数会运行
  // from:之前的路由对象  (this.$route)
  // to: 即将进入的路由对象 (this.$route)
  // next: 确认导航的一个函数  调用该函数(无参),就会直接进入to, 调用该函数(传入参数),根据传入参数进入新的导航
  if (to.meta.auth) {
    const status = store.getters["loginUser/status"];
    if (status === "loading") {

      //刚开始为loading  会一直卡在加载的页面
      next({
        path: "/loading",
        query: {
          returnurl: to.fullPath,   //参数中带上原访问的页面uri
        },
      });
      return;
    } else if(status === "login"){
    	//状态为登录进入页面
      next()
    }
    else if (status === "unlogin") {
      alert("你没有登录,请先登录");
      next({
        path: "/login",
        query: {
          returnurl: to.fullPath,  //参数中带上原要访问的页面uri
        },
      });
      return;
    }
  }
  next();
});
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值