Vue3+Ts实现路由守卫

路由守卫

前言

博主本期主要讲解的是Vue3如何实现特定路由的路由守卫。那么好,本期正式开始。

路由守卫是啥

路由守卫其实是前端为了防止用户通过路由访问到它不能被访问的页面,这一点可以在后端实现,也可以通过前端实现,那么前端实现的方式之一就是路由守卫。

  • 场景一:当用户没有登录,但是通过路由想调用首页。路由守卫就可以在next进入路由前,进行校验操作。
  • 场景二:当用户登录成功,同时他知道管理员的某个导航栏路由,想通过该路由进入管理员页面,实现越权操作,那么也可以通过路由守卫进行拦截操作。

总的来说,路由守卫就是为了防止未登录的用户进入页面或用户越权行为出现。出现的一种机制,这种机制就是在跳转路由前,可以进行通过自定义函数进行校验,校验成功后再成功跳转。否则就会跳转回原页面。

实现方式

基于上文所讲我们了解到,是用来校验用户是否登录和用户权限两个问题,而基于此,路由守卫又分为两种方式:

第一种:全局守卫

顾名思义,全局守卫的意思是除了登录外所有组件跳转前都需要校验。通俗来说就是,确认用户或管理员是否登录。

举例说明:

首先我们在router文件夹下的index.ts文件中导入相关依赖。

javascript 复制代码
import { NavigationGuardNext, RouteLocationNormalized, RouteLocationNormalizedLoaded, Router } from 'vue-router';

导入成功后,我们使用下述代码实现校验功能

javascript 复制代码
router.beforeEach((to: RouteLocationNormalized, from: RouteLocationNormalizedLoaded, next: NavigationGuardNext) => {

  // 检查用户是否登录
  const isAuthenticated = checkLogin(); // 自定义函数,检查用户是否已登录

  if (to.name !== 'login' && !isAuthenticated) {
    // 如果未登录且目标路由不是登录页,导航到登录页
    next({ name: 'login' });
  } else {
    // 如果已登录或目标路由是登录页,继续导航
    next();
  }
});

在上述代码中,我们发现router.beforeEach就是全局守卫的定义名,在方法体中,我们首先通过自定义函checkLogin数来判断用户是否登录,checkLogin要根据自身项目来判断,可以用sessionStorage来进行是否登录数据存储,也可以通过token等值进行校验,这里就不赘述了。下一步就是判断这个名称是否不是登陆页且checkLogin的返回值是false,如果是,则跳转回login,也就是登录页面,如果不是则成功跳转。

以上是第一种全局守卫,第二种就是局部路由

第二种:局部守卫

局部路由实际就是对某些特定的组件进行路由守卫,比如我有三个角色,而这三个角色看到的页面是不同的,他们之间不能互相看到各自的页面,那么就可以使用路由守卫。

也是和第一种一样,需要导入依赖。

javascript 复制代码
import { NavigationGuardNext, RouteLocationNormalized, RouteLocationNormalizedLoaded, Router } from 'vue-router';

然后需要在组件中用beforeEnter方法来实现路由守卫。

javascript 复制代码
{
    path: '/moneyManager',
    name: 'moneyManager',
    component: moneyManager,
    beforeEnter: (to: RouteLocationNormalized, from: RouteLocationNormalizedLoaded, next: NavigationGuardNext) => {
      const hasPermission = checkUserPermission(); // 自定义函数,检查用户权限

      if (hasPermission!='0') {
        next({ name: 'login' }); // 例如,导航到登录
      } else {
        next();
      }
    }
  },

主要是自定义方法不同,可以给大家看下我写的自定义方法。

javascript 复制代码
function checkUserPermission(){
  if(!sessionStorage.getItem('role')){
    return -1;
  }
  return sessionStorage.getItem('role');
}

这里我是通过在登录时像sessionStorage传入一个role值,用role是否存在判断登录是否成功,用role等于几判断它是哪种角色。

以上就是本文的全部内容。

相关推荐
你挚爱的强哥2 小时前
✅✅✅【Vue.js】sd.js基于jQuery Ajax最新原生完整版for凯哥API版本
javascript·vue.js·jquery
susu10830189113 小时前
vue3中父div设置display flex,2个子div重叠
前端·javascript·vue.js
Jacky(易小天)5 小时前
MongoDB比较查询操作符中英对照表及实例详解
数据库·mongodb·typescript·比较操作符
天天进步20155 小时前
Vue+Springboot用Websocket实现协同编辑
vue.js·spring boot·websocket
疯狂的沙粒6 小时前
如何在Vue项目中应用TypeScript?应该注意那些点?
前端·vue.js·typescript
小镇程序员6 小时前
vue2 src_Todolist全局总线事件版本
前端·javascript·vue.js
疯狂的沙粒6 小时前
对 TypeScript 中函数如何更好的理解及使用?与 JavaScript 函数有哪些区别?
前端·javascript·typescript
想自律的露西西★7 小时前
用el-scrollbar实现滚动条,拖动滚动条可以滚动,但是通过鼠标滑轮却无效
前端·javascript·css·vue.js·elementui·前端框架·html5
白墨阳7 小时前
vue3:瀑布流
前端·javascript·vue.js
程序媛-徐师姐8 小时前
Java 基于SpringBoot+vue框架的老年医疗保健网站
java·vue.js·spring boot·老年医疗保健·老年 医疗保健