使用 addRouteMiddleware 动态添加中间

news2025/1/31 3:17:32

title: 使用 addRouteMiddleware 动态添加中间
date: 2024/8/4
updated: 2024/8/4
author: cmdragon

excerpt:
摘要:文章介绍了Nuxt3中addRouteMiddleware的使用方法,该功能允许开发者动态添加路由中间件,以实现诸如权限检查、动态重定向及路由变化时的特定操作。内容涵盖路由中间件的概念、addRouteMiddleware的语法、参数、使用示例(包括匿名中间件、命名中间件、全局中间件、覆盖现有中间件)及调试技巧。强调了此功能为Nuxt3应用带来的灵活性和便利性。

categories:

  • 前端开发

tags:

  • Nuxt3
  • 中间件
  • 路由
  • 动态
  • 权限
  • 重定向
  • 导航

2024_08_04 10_01_31.png

freecompress-cmdragon_cn.png

扫描二维码关注或者微信搜一搜:编程智域 前端至全栈交流与成长

在 Nuxt3 中,addRouteMiddleware 允许开发者在应用程序中动态添加路由中间件。这为你提供了灵活性,可以在不同情况下执行导航守卫,例如处理权限、重定向,以及在路由变化时执行特定操作。

什么是路由中间件?

路由中间件是一个函数,可以在用户导航到特定路由前执行某些操作。它通常用于:

  • 检查用户权限
  • 动态重定向用户
  • 登录或加载数据

在 Nuxt3 中,所有中间件通常位于 middleware/ 目录中,但通过使用 addRouteMiddleware,你可以在运行时动态添加它们。

addRouteMiddleware 语法与参数

语法

addRouteMiddleware(name: string | RouteMiddleware, middleware?: RouteMiddleware, options: AddRouteMiddlewareOptions = {})

参数

  • name: (string | RouteMiddleware)

    • 可以是字符串(用于命名中间件)或一个路由中间件函数,类型为 RouteMiddleware
  • middleware: (RouteMiddleware)

    • 这是一个函数,接受两个参数:
      • to: 目标路由对象,包含用户要访问的路由信息。
      • from: 源路由对象,包含用户当前所在的路由信息。
  • options: (AddRouteMiddlewareOptions)

    • 一个可选的对象,用来设置中间件的额外选项。当前可以设置的选项是:
      • global: (boolean) 如果设置为 true,则该中间件为全局中间件,默认为 false

使用 addRouteMiddleware

1. 匿名路由中间件

在你需要简单的逻辑处理时,创建匿名路由中间件非常方便。

示例:禁止访问特定页面

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
  addRouteMiddleware((to, from) => {
    // 如果用户尝试访问 /forbidden 路径,则阻止导航
    if (to.path === '/forbidden') {
      console.log('访问被阻止:用户尝试访问从未授权的路径:', to.path);
      return false; // 阻止导航
    }
  });
});
解释:

在上述示例中,如果用户尝试访问 /forbidden 页面,导航将被阻止并输出日志。

2. 命名路由中间件

命名路由中间件可以用字符串命名,便于后续调用和覆盖。

示例:记录每次导航日志

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
  addRouteMiddleware('logger-middleware', (to, from) => {
    console.log('用户从', from.path, '导航到', to.path);
  });
});
解释:

在这个示例中,我们为中间件命名为 logger-middleware。这个中间件将在每次导航时输出用户的导航日志。可以通过 addRouteMiddleware 的方式再次覆盖同名中间件。

3. 全局路由中间件

全局中间件在每次路由变更时都会执行,适用于需要在每个路由之间共享逻辑的场景。

示例:全局访问控制检查

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
  addRouteMiddleware('auth-check', (to, from) => {
    const isAuthorized = false; // 假设这里是你的认证逻辑

    if (!isAuthorized) {
      console.warn('用户未授权,重定向到登录页面');
      return navigateTo('/login'); // 重定向到登录页面
    }
  }, { global: true });
});
解释:

在这个示例中,我们创建了一个全局中间件 auth-check,每次路由更改时都会检查用户是否被授权。如果用户未授权,则重定向到 /login 页面。

4. 覆盖现有中间件

当使用命名的中间件时,新的中间件将覆盖已有的同名中间件。如下所示:

// middleware/auth.js
export default defineNuxtRouteMiddleware((to, from) => {
  // 原有逻辑
});

// 然后在 plugins 中添加覆盖
// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
  addRouteMiddleware('auth', (to, from) => {
    console.log('覆盖了旧的 auth 中间件');
    // 新的逻辑
  });
});

在这个例子中,plugins/my-plugin.ts 中的中间件将覆盖 middleware/auth.js 中的内容。这样的特性可以帮助我们在特定条件下修改原有逻辑。

进行中间件调试

在开发过程中,调试中间件是个重要步骤。可以使用简单的 console.log 输出调试信息,帮助理解中间件的执行流程。例如:

// plugins/my-plugin.ts
export default defineNuxtPlugin(() => {
  addRouteMiddleware((to, from) => {
    console.log('[Middleware Debug]', 'From:', from.path, 'To:', to.path);
  });
});

这可以帮助你确认中间件的执行顺序和路径变更。

总结

通过使用 addRouteMiddleware,你可以灵活地在 Nuxt3 应用中添加、覆盖和管理路由中间件。这为实现复杂的导航逻辑、访问控制和数据处理提供了必要工具。

余下文章内容请点击跳转至 个人博客页面 或者 扫码关注或者微信搜一搜:编程智域 前端至全栈交流与成长,阅读完整的文章:使用 addRouteMiddleware 动态添加中间 | cmdragon’s Blog

往期文章归档:

  • 使用 abortNavigation 阻止导航 | cmdragon’s Blog
  • 使用 $fetch 进行 HTTP 请求 | cmdragon’s Blog
  • 使用 useState 管理响应式状态 | cmdragon’s Blog
  • 使用 useServerSeoMeta 优化您的网站 SEO | cmdragon’s Blog
  • 使用 useSeoMeta 进行 SEO 配置 | cmdragon’s Blog
  • Nuxt.js必读:轻松掌握运行时配置与 useRuntimeConfig | cmdragon’s Blog
  • Nuxt.js 路由管理:useRouter 方法与路由中间件应用 | cmdragon’s Blog
  • useRoute 函数的详细介绍与使用示例 | cmdragon’s Blog
  • 使用 useRequestURL 组合函数访问请求URL | cmdragon’s Blog
  • Nuxt.js 环境变量配置与使用 | cmdragon’s Blog
  • 服务端渲染中的数据获取:结合 useRequestHeaders 与 useFetch | cmdragon’s Blog
  • 使用 useRequestEvent Hook 访问请求事件 | cmdragon’s Blog
  • 使用 useNuxtData 进行高效的数据获取与管理 | cmdragon’s Blog
  • Nuxt 3 使用指南:掌握 useNuxtApp 和运行时上下文 | cmdragon’s Blog
  • 使用 useLazyFetch 进行异步数据获取 | cmdragon’s Blog
  • 使用 useLazyAsyncData 提升数据加载体验 | cmdragon’s Blog
  • Nuxt.js 中使用 useHydration 实现数据水合与同步 | cmdragon’s Blog

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1977550.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

html+css 实现hover双层按钮

前言:哈喽,大家好,今天给大家分享htmlcss 绚丽效果!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏关注哦 💕 文…

AI人工智能开发环境配置

AI人工智能 为什么使用Python来开发AI 人工智能被认为是未来的趋势技术。 已经有了许多应用程序。 因此,许多公司和研究人员都对此感兴趣。 但是这里出现的主要问题是,在哪种编程语言中可以开发这些 AI 应用程序? 有各种编程语言&#xff0c…

Stable Diffusion绘画 | 图生图-基础使用介绍—提示词反推

按默认设置直接出图 拖入图片值图生图框中,保持默认设置,直接生成图片,出图效果如下: 因为重绘幅度0.7,所出图片与原图有差异,但整体的框架构图与颜色与原图类似。 输入关键词后出图 在正向提示词中输入…

PMP–知识卡片--Scrum框架

定义 Scrum框架包含由产品负责人、开发团队、敏捷专家构成的Scrum团队,以及活动工件。框架中的每一个组件都服务于一个特定的目标,且是Scrum成功和运用的基本要素。 Scrum的规则将角色、活动和工件绑定在一起,管理它们之间的关系和交互。 …

JavaEE 第2节 线程安全知识铺垫1

目录 一、通过jconsole.exe查看线程状态的方法 二、Thread类的几种常见属性 三、线程状态 一、通过jconsole.exe查看线程状态的方法 通过jconsole查看线程状态非常实用的方式 只要你安装了jdk,大致按照这个目录就可以找到这个可执行程序: 然后双击这…

YOLOv10改进 | 注意力篇 | YOLOv10引入24年最新的上下文锚注意力机制(CAA),并构建C2f_CAA(适用于小目标检测)

1. CAA介绍 1.1 摘要:遥感图像中的目标检测面临着越来越多的挑战,包括目标尺度的变化和背景的多样性。先前的方法试图通过扩大骨干的空间感受野来解决这些挑战,无论是通过大核卷积还是扩张卷积。然而,前者通常会引入相当大的背景噪声,而后者则会产生过于稀疏的特征表示。…

[CTF]-PWN:ORW题型综合解析

经典ORW: 例题(极客大挑战 2019 Not Bad): 这里使用mmap函数创造了一个内存映射区域 从地址0x123000开始,大小位0x1000 权限为可写可执行(可读0x1,可写0x2,可执行0x3)…

Halcon 二维匹配

匹配:在训练图像中呈现一个所谓的模板。系统从这个模板中派生出一个模型,通过使用该模型来定位于搜索图像中的相似模板对象。此方法能够处理打光、杂乱、位置和旋转变换的图像。 匹配优点:鲁棒性和灵活性。匹配不需要对目标进行任何形式的分割…

50 选择结构

常见的选择结构有单分支选择结构、双分支选择结构、多分支选择结构及嵌套的分支结构,也可以构造跳转表来实现类似的逻辑。循环结构和异常处理结构中也可以实现带有 else 子句,可以看作特殊形式的选择结构。 所有的 Python 合法表达式都可以作为条件表达…

MySQL数据库入门:掌握数据管理的关键步骤!

前言 竹竹零将带您深入探索MySQL数据库的基础知识和实用技能,一同走进Java逻辑控制语句的 学习吧!!! 本节目标 数据库的操作:创建数据库、删除数据库常用数据类型表的操作:创建表、删除表 1. 数据库的操作…

跨域以及解决方案

禹神:一小时彻底搞懂跨域&解决方案_哔哩哔哩_bilibili该直播回放对跨域的多种解决方案进行了梳理,内容包括:分析同源策略、分析预检请求、跨域的多种解决方案(CORS、JSONP、代理)、同时也从后端人员角度梳理了各种…

计算机毕业设计选题推荐-学生作业管理系统-Java/Python项目实战

✨作者主页:IT研究室✨ 个人简介:曾从事计算机专业培训教学,擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

一次性下发100w的优惠券/短信/二维码,兼顾线程池参数可配置

1、场景需求分析 针对6.18,11.11这种场景,平台一次性发布500w张优惠券,或者对于锁单用户统一发下100w张确认信息,同时我们平时有抢购茅台的场景,京东一次性发布10w个验证码,主要是针对高并发多线程大数据批处理任务的场景,一般用于二维码、优惠券、邮件、短信等场景。 …

MyBatis的适用场合与优势

MyBatis的适用场合与优势 1、适用场合2、优势 💖The Begin💖点点关注,收藏不迷路💖 1、适用场合 SQL灵活控制: 适合需要精确控制SQL语句生成和执行的项目。 高性能需求: 对于性能要求高的系统,…

02:【stm32】工程模板的创建

工程模板的创建 1、创建工程文件2、创建STM32的启动文件3、Keil软件里面添加启动文件4、创建我们编写程序的文件夹5、创建存放标准库函数的文件夹6、Keil软件的一些设置 1、创建工程文件 2、创建STM32的启动文件 ①创建Start文件夹用来保存STM32的启动文件 ②下载STM32的固件库…

Apple在Swift中引入同态加密

--->更多内容&#xff0c;请移步“鲁班秘笈”&#xff01;&#xff01;<--- 在计算过程中确保数据隐私和安全性很重要&#xff0c;尤其是在使用云服务。传统的加密方法要求在处理数据之前对数据进行解密&#xff0c;使其面临潜在风险。同态加密是隐私计算的分支&#xf…

C Primer Plus 第5章——第二篇

你该逆袭了 第5 章:重点摘录 三、表达式和语句1、表达式2、语句&#xff08;1&#xff09;副作用 和 序列点&#xff08;a&#xff09;副作用&#xff08;b&#xff09;序列点1、完整表达式 3、复合语句&#xff08;块&#xff09; 四、类型转换1、强制类型转换运算符2、总结&a…

修改 WSL 安装的子系统的位置,节约C盘空间

问题描述 由于 WSL 玩了一阵子&#xff0c;发现C盘的磁盘空间快没了&#xff0c;如下图所示 感觉以后还是不要磁盘分区了&#xff0c;全部在C盘也没什么不好的。 挪动子系统方法 如下图所示&#xff0c;为了方便演示&#xff0c;我们安装了 ubuntu 子系统&#xff0c;并且打…

快讯 | AI牙医震撼登场:15分钟完成牙冠准备,速度超人类8倍!

在数字化浪潮的推动下&#xff0c;人工智能&#xff08;AI&#xff09;正成为塑造未来的关键力量。硅纪元视角栏目紧跟AI科技的最新发展&#xff0c;捕捉行业动态&#xff1b;提供深入的新闻解读&#xff0c;助您洞悉技术背后的逻辑&#xff1b;汇聚行业专家的见解&#xff0c;…

计算几何 点乘 两点间距离 两向量夹角

点乘 点乘&#xff08;也称为内积、标量积或数量积&#xff09;是线性代数中两个向量之间的一种运算&#xff0c;其结果是一个标量&#xff08;即一个单一的数&#xff0c;而不是向量&#xff09;。对于两个n维向量a(a 1 ,a 2 ,…,a n )和b(b 1 ,b 2 ,…,b n )&#xff0c;它们…