前端导航守卫

导航守卫

为了解决在地址栏手动输入 /login 才显示登录界面的问题,可以加入导航守卫进行判断。

如何使用导航守卫?请访问 Vue 官网 模板语法 页面,点击顶部栏的“生态系统”找到 Vue Router,跳转页面后点击“入门”。接着在侧边栏中找到“导航守卫”。

全局前置守卫

可以使用 router.beforeEach 注册一个全局前置守卫:

router.beforeEach((to, from) => {
  // 返回 false 以取消导航
  return false;
});

// from 代表从哪里来
// to 代表将要跳转到哪个页面

当一个导航触发时,全局前置守卫按照创建顺序调用。

将上述代码复制到 router/index.ts 中配置导航守卫:

// 全局前置守卫
router.beforeEach((to, from) => {
    if (to.path === '/main') {
        // 判断是否已经登录
        let username = sessionStorage.getItem("username");
        if (username != null) {
            // 已经登录,放行
            return true;
        } else {
            // 未登录,跳转到登录页面
            router.push("/login");
            return false;
        }
    }
});

说明

  1. 路由配置
    • 主界面路由 /main 以及登录页面路由 /login
  2. 全局前置守卫
    • 使用 router.beforeEach 注册一个全局前置守卫。
    • 检查目标路由是否是 /main,如果是,则判断用户是否已经登录(通过 sessionStorage 检查用户名)。
    • 如果用户已经登录,放行导航;如果用户未登录,跳转到登录页面。

这样,当用户未登录时,任何试图访问 /main 的请求都会被重定向到登录页面,确保用户必须先登录。

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值