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的局部生效中间件!

相关推荐
像素之间1 分钟前
elementui中rules的validator 用法
前端·javascript·elementui
小高0075 分钟前
🚀把 async/await 拆成 4 块乐高!面试官当场鼓掌👏
前端·javascript·面试
2401_8370885010 分钟前
AJAX快速入门 - 四个核心步骤
前端·javascript·ajax
无羡仙17 分钟前
当点击链接不再刷新页面
前端·javascript·html
雲墨款哥18 分钟前
为什么我的this.name输出了空字符串?严格模式与作用域链的微妙关系
前端·javascript·面试
jqq66624 分钟前
Vue3脚手架实现(十、补之前配置)
前端·javascript·vue.js
电商数据girl1 小时前
如何利用API接口与网页爬虫协同进行电商平台商品数据采集?
大数据·开发语言·人工智能·python·django·json
小螺号dididi吹2 小时前
【React】状态管理
前端·javascript·react.js
代码的余温2 小时前
React Refs:直接操作DOM的终极指南
前端·javascript·react.js
一只小风华~2 小时前
JavaScript 定时器
开发语言·前端·javascript·vue.js·web