前端面试题47(在动态控制路由时,如何防止未授权用户访问受保护的页面?)

在Vue中,防止未授权用户访问受保护页面通常涉及到使用路由守卫(Route Guards)。路由守卫允许你在路由发生改变前或后执行一些逻辑,比如检查用户是否已登录或者有访问某个页面的权限。下面是一些常见的路由守卫类型及其使用方式:

1. 全局前置守卫(Global Before Guards)

beforeEach 守卫会在每次路由转换前调用,你可以在这里检查用户的登录状态和权限。

javascript 复制代码
const router = new VueRouter({
  routes: [...]
});

router.beforeEach((to, from, next) => {
  const requiresAuth = to.matched.some(record => record.meta.requiresAuth);
  
  if (requiresAuth && !auth.isLoggedIn()) {
    // 如果页面需要认证并且用户没有登录,则重定向到登录页面
    next({ path: '/login' });
  } else {
    next();
  }
});

2. 路由级守卫(Route-Level Guards)

在路由配置中,你可以直接在路由对象上添加守卫,这使得某些路由具有更细粒度的控制。

javascript 复制代码
const routes = [
  {
    path: '/protected',
    name: 'ProtectedPage',
    component: ProtectedPage,
    meta: { requiresAuth: true },
    beforeEnter: (to, from, next) => {
      if (!auth.isLoggedIn()) {
        return next('/login');
      }
      next();
    }
  },
  // ...
];

3. 组件内的守卫(Component Guards)

你还可以在组件内部使用守卫,比如 beforeRouteEnterbeforeRouteUpdate

javascript 复制代码
export default {
  // ...
  beforeRouteEnter(to, from, next) {
    if (!auth.isLoggedIn()) {
      next('/login');
    } else {
      next();
    }
  },
  // ...
};

4. 使用 Vuex Store

结合 Vuex,你可以更方便地在全局范围内管理用户的登录状态和权限信息。在登录时,将权限信息存储在 Vuex store 中,然后在路由守卫中读取这些信息。

javascript 复制代码
// store.js
const store = new Vuex.Store({
  state: {
    isLoggedIn: false,
    userPermissions: []
  },
  mutations: {
    SET_LOGIN_STATUS(state, status) {
      state.isLoggedIn = status;
    },
    SET_PERMISSIONS(state, permissions) {
      state.userPermissions = permissions;
    }
  },
  // ...
});

然后在路由守卫中检查 store.state.isLoggedInstore.state.userPermissions

实现细节

  • 权限检查:确保你的守卫逻辑能够正确检查用户权限,例如,对于管理员级别的页面,检查用户是否具有管理员权限。
  • 重定向:如果用户没有必要的权限,通常会重定向到登录页面或一个友好的错误页面。
  • 错误处理:考虑加入错误处理机制,比如网络请求失败时的处理。
相关推荐
大橙子额23 分钟前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js
WooaiJava2 小时前
AI 智能助手项目面试技术要点总结(前端部分)
javascript·大模型·html5
LYFlied2 小时前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
爱喝白开水a2 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
Never_Satisfied2 小时前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
董世昌412 小时前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
B站_计算机毕业设计之家2 小时前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
WeiXiao_Hyy3 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
吃杠碰小鸡3 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone3 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word