Node.js局部生效的中间件

目录

[1. 目录结构](#1. 目录结构)

[2. 代码实现](#2. 代码实现)

[2.1 安装Express](#2.1 安装Express)

[2.2 app.js - 主文件](#2.2 app.js - 主文件)

[2.3 authMiddleware.js - 局部生效的中间件](#2.3 authMiddleware.js - 局部生效的中间件)

[3. 程序运行结果](#3. 程序运行结果)

[4. 总结](#4. 总结)


在Node.js的Express框架中,局部生效的中间件是指仅在特定路由或路由组中生效的中间件。它可以用于权限验证、数据过滤、日志记录等特定功能,而不会影响整个应用的所有请求。下面我们通过代码示例详细介绍如何实现局部生效的中间件。


1. 目录结构

bash 复制代码
/your-project
  ├── app.js                # 主文件,启动应用
  ├── middleware
  │   └── authMiddleware.js  # 局部生效的中间件(模拟身份验证)
  └── package.json          # 项目依赖管理文件

2. 代码实现

2.1 安装Express

如果你还没有安装Express,请先执行以下命令:

bash 复制代码
npm init -y
npm install express

2.2 app.js - 主文件

app.js是应用的主入口,我们将在这里引入局部中间件,并应用到指定的路由。

javascript 复制代码
// app.js
const express = require('express');
const app = express();

// 引入局部中间件
const authMiddleware = require('./middleware/authMiddleware');

// 定义公共路由(不需要中间件)
app.get('/', (req, res) => {
  res.send('<h1>Welcome to the Home Page</h1>');
});

// 使用局部中间件的路由
app.get('/dashboard', authMiddleware, (req, res) => {
  res.send('<h1>Welcome to the Dashboard</h1>');
});

app.get('/profile', authMiddleware, (req, res) => {
  res.send('<h1>Welcome to Your Profile</h1>');
});

// 监听端口
const PORT = 3000;
app.listen(PORT, () => {
  console.log(`Server is running on http://localhost:${PORT}`);
});

说明:

  • authMiddleware 仅用于/dashboard/profile路由,而/路由不受影响。

  • 只有访问受保护的路由时,中间件才会执行身份验证。


2.3 authMiddleware.js - 局部生效的中间件

authMiddleware.js是一个模拟身份验证的中间件,它检查请求中是否带有?auth=true参数,来决定是否允许访问。

javascript 复制代码
// middleware/authMiddleware.js
const authMiddleware = (req, res, next) => {
  if (req.query.auth === 'true') {
    console.log('Authentication successful');
    next(); // 继续执行路由处理
  } else {
    res.status(403).send('<h1>Access Denied: Authentication Required</h1>');
  }
};

module.exports = authMiddleware;

说明:

  • 这个中间件检查查询参数auth是否为true,如果是,则允许访问,否则返回403错误,并提示"访问被拒绝"。

3. 程序运行结果

启动应用:

javascript 复制代码
node app.js

然后访问以下地址:

  • 访问 http://localhost:3000/(无需认证)

    • 终端无额外输出

    • 页面显示:

      javascript 复制代码
      <h1>Welcome to the Home Page</h1>
  • 访问 http://localhost:3000/dashboard

    • 终端无输出,页面显示:

      javascript 复制代码
      <h1>Access Denied: Authentication Required</h1>
  • 访问 http://localhost:3000/dashboard?auth=true

    • 终端输出:

      javascript 复制代码
      Authentication successful
    • 页面显示:

      javascript 复制代码
      <h1>Welcome to the Dashboard</h1>

4. 总结

  • 局部中间件 只影响特定的路由,而不会全局生效。

  • 通过在路由定义中传递中间件(如app.get('/dashboard', authMiddleware, handler)),可以控制它的作用范围。

  • 本示例使用了简单的身份验证逻辑(查询参数),在实际应用中可以扩展为基于JWT或Session的认证机制。

希望本教程能帮助你理解Node.js的局部生效中间件!

相关推荐
看到我请叫我铁锤15 小时前
vue3中THINGJS初始化步骤
前端·javascript·vue.js·3d
q***252115 小时前
SpringMVC 请求参数接收
前端·javascript·算法
谢尔登15 小时前
defineProperty如何弥补数组响应式不足的缺陷
前端·javascript·vue.js
skywalk816316 小时前
FreeBSD系统安装VSCode Server(未成功,后来是在FreeBSD系统里的Linux虚拟子系统里安装启动了Code Server)
ide·vscode·编辑器·freebsd
深海潜水员16 小时前
【MonoGame游戏开发】| 牧场物语实现 第一卷 : 农场基础实现 (下)
vscode·游戏·c#·.net·monogame
李宥小哥16 小时前
Redis13-实践-短信登录
中间件
a***560616 小时前
node.js下载、安装、设置国内镜像源(永久)(Windows11)
node.js
利刃大大17 小时前
【c++中间件】语音识别SDK && 二次封装
开发语言·c++·中间件·语音识别
T***u33317 小时前
前端框架在性能优化中的实践
javascript·vue.js·前端框架
jingling55518 小时前
vue | 在 Vue 3 项目中集成高德地图(AMap)
前端·javascript·vue.js