当前位置: 首页 > news >正文

Vue实现路由守卫

Vue实现路由守卫

一、概念

路由守卫(Navigation Guards)本质上就是 在路由跳转前后,拦截用户导航并做一些逻辑处理的钩子函数
常见用途有:

  • 鉴权控制:比如没有登录就不允许进入某些页面。
  • 数据预加载:在进入某个页面前,提前拉取数据。
  • 页面跳转控制:比如离开页面前弹出“是否保存更改”的提示。

简单理解:路由守卫就是 Vue Router 提供的一种“钩子函数”,用来控制页面导航的行为。

二、类型

Vue Router 提供了三类守卫:

(1)全局守卫

对所有路由跳转都生效。

// 全局前置守卫router.beforeEach((to, from, next) => {const token = localStorage.getItem('token')if (to.meta.requiresAuth && !token) {// 需要登录,但没 token,跳转到登录next('/login')} else {next()}})// 全局后置守卫(一般用来修改标题等)router.afterEach((to) => {document.title = to.meta.title || '默认标题'})export default router

(2)路由独享守卫

只针对某一个路由生效。

{path: '/profile',component: () => import('@/views/Profile.vue'),beforeEnter: (to, from, next) => {const token = localStorage.getItem('token')if (!token) {next('/login')} else {next()}}}

(3)组件内守卫

直接写在组件里,对进入/离开当前组件生效。

export default {name: 'Profile',// 进入当前组件之前beforeRouteEnter(to, from, next) {console.log('即将进入 Profile 页面')next()},// 路由更新(比如 /profile/1 -> /profile/2)beforeRouteUpdate(to, from, next) {console.log('路由参数变化,更新页面数据')next()},// 离开当前组件时beforeRouteLeave(to, from, next) {const answer = window.confirm('确定要离开吗?未保存的数据会丢失')if (answer) {next()} else {next(false) // 阻止导航}}}

三、实战

以下为作者的演示:

  1. 全局守卫
  2. 如果token过期或token错误会返回到登录页面

注意:以上效果需要配合JWT来实现,详情请看我的博客文章:

JWT令牌-CSDN博客

在index.Js文件中写入全局守卫:

// 全局前置守卫router.beforeEach((to, from, next) => {const token = localStorage.getItem('token') // 从本地取 tokenif (to.meta.requiresAuth && !token) {// 如果需要登录且没有 token,就跳到登录页next({ path: '/' })} else {next() // 其他情况放行}})

在request.Js中添加拦截器:

/

// 响应拦截器:统一处理 401request.interceptors.response.use((response) => response,(error) => {if (error.response && error.response.status === 401) {localStorage.removeItem("token"); // 清除过期 tokenrouter.push("/"); // 跳转到登录页}return Promise.reject(error);});

可以试验一下,登录成功进入ai页面后:

打开F12,打开本地存储,将token删除,回到页面,并刷新。。

这时当前端发送的请求头不带token令牌时,后端会返回401,,axois拦截器会拦截到并且退回登录页面:

http://www.dtcms.com/a/392292.html

相关文章:

  • Coze源码分析-资源库-删除工作流-前端源码-核心接口
  • 安踏集团 X OB Cloud:新零售创新如何有“底”和有“数”
  • Web3艺术品交易应用方案
  • Spring 事务管理详解:保障数据一致性的实践指南
  • 软考中级-软件设计师 答题解题思路
  • Java IDEA学习之路:第二周课程笔记归纳
  • SQL语句一文通
  • Ubuntu22.04 双显卡系统使用集显 DRM 渲染的完整流程记录
  • Coze源码分析-资源库-删除工作流-后端源码-IDL/API/应用/领域
  • MySQL库和表的操作语句
  • python、类
  • NumPy高级技巧:向量化、广播与einsum的高效使用
  • GD32VW553-IOT 基于 vscode 的 msdk 移植(基于Cmake)
  • Filter 过滤器详解与使用指南
  • 养成合成小游戏抖音快手微信小程序看广告流量主开源
  • 在 Ubuntu 系统下安装 Conda
  • ac8257 android 9 SYSTEM_LAST_KMSG
  • ARM 架构与嵌入式系统
  • ARM(14) - LCD(1)清屏和画图形
  • Linux第十九讲:传输层协议UDP
  • 计算机网络学习(四、网络层)
  • 开启科学计算之旅:《MATLAB程序设计》课程导览
  • MATLAB | 数学模型 | 传染病 SIR 模型的参数确定
  • MATLAB基本运算(2)
  • 小红书数据分析面试题及参考答案
  • SpringCloudStream:消息驱动组件
  • ret2text-CTFHub技能树
  • VirtualBox 7 虚拟机的硬盘如何扩大?
  • React新闻发布系统 权限列表开发
  • 23种设计模式之【策略模式】-核心原理与 Java 实践