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

Node.js自定义中间件

目录

Node.js 自定义中间件详细介绍

1. 目录结构

2. 什么是自定义中间件?

3. 代码实现

1. 自定义日志中间件(记录请求信息)

2. 自定义身份验证中间件(校验用户权限)

3. 自定义请求时间中间件(记录请求发生时间)

4. 总结


在 Node.js 的 Express 框架中,中间件是处理 HTTP 请求的核心部分,开发者可以使用自定义中间件来增强功能,例如日志记录、身份验证、错误处理等。本文将详细介绍如何创建和使用自定义中间件,并提供完整代码示例,帮助开发者更深入理解 Express 中间件的用法。


1. 目录结构

/your-project
  ├── app.js                # 主文件,启动应用
  ├── middleware
  │   ├── logger.js         # 自定义日志中间件
  │   ├── auth.js           # 自定义身份验证中间件
  │   ├── requestTime.js    # 自定义请求时间中间件
  └── package.json          # 依赖管理文件

2. 什么是自定义中间件?

自定义中间件是开发者自己编写的函数,位于请求到达路由之前或响应返回客户端之前,通常用于:

  • 记录请求日志

  • 处理用户身份验证

  • 解析请求数据

  • 处理错误

自定义中间件格式:

const middlewareFunction = (req, res, next) => {
  // 处理逻辑
  next(); // 继续执行下一个中间件或路由
};

module.exports = middlewareFunction;

3. 代码实现

1. 自定义日志中间件(记录请求信息)

文件名:middleware/logger.js

// middleware/logger.js
const logger = (req, res, next) => {
  console.log(`[${new Date().toISOString()}] ${req.method} ${req.url}`);
  next();
};

module.exports = logger;

app.js 中使用:

// app.js
const express = require('express');
const app = express();
const logger = require('./middleware/logger');

// 全局使用日志中间件
app.use(logger);

app.get('/', (req, res) => {
  res.send('<h1>Home Page</h1>');
});

app.listen(3000, () => {
  console.log('Server running on http://localhost:3000');
});

运行结果:
访问 http://localhost:3000/ 时,终端输出:

[2025-04-01T12:00:00.000Z] GET /

2. 自定义身份验证中间件(校验用户权限)

文件名:middleware/auth.js

// middleware/auth.js
const auth = (req, res, next) => {
  if (req.query.auth === 'true') {
    next(); // 通过验证,继续执行
  } else {
    res.status(403).send('<h1>Access Denied</h1>');
  }
};

module.exports = auth;

app.js 中使用:

const auth = require('./middleware/auth');

app.get('/dashboard', auth, (req, res) => {
  res.send('<h1>Welcome to the Dashboard</h1>');
});

运行结果:
访问 http://localhost:3000/dashboard?auth=true

Welcome to the Dashboard

访问 http://localhost:3000/dashboard

Access Denied

3. 自定义请求时间中间件(记录请求发生时间)

文件名:middleware/requestTime.js

// middleware/requestTime.js
const requestTime = (req, res, next) => {
  req.requestTime = new Date().toISOString();
  next();
};

module.exports = requestTime;

app.js 中使用:

const requestTime = require('./middleware/requestTime');

app.use(requestTime);

app.get('/time', (req, res) => {
  res.send(`<h1>Request received at: ${req.requestTime}</h1>`);
});

运行结果:
访问 http://localhost:3000/time

Request received at: 2025-04-01T12:00:00.000Z

4. 总结

  1. 日志中间件 - 记录请求信息,方便调试。

  2. 身份验证中间件 - 校验用户权限,控制访问权限。

  3. 请求时间中间件 - 记录请求时间,方便分析请求时间点。

本教程提供完整代码和运行示例,帮助开发者掌握 Express 自定义中间件的用法,提高 Node.js 应用的可维护性和扩展性!

 

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

相关文章:

  • 【NLP 57、LLM通用能力评价方式】
  • Shell脚本的学习
  • Python基础全解析:从输入输出到字符编码的深度探索
  • MySQL体系架构(一)
  • Apache Camel指南-第一章:路由定义构建块
  • 在 VMware 中为 Ubuntu 24.04 虚拟机设置共享文件夹后,在虚拟机中未能看到共享的内容
  • JavaScript学习23-定时器
  • MCP基础学习计划:从MCP入门到项目构建的全面指南
  • 【AI技术】Function Calling、LangChain、MCP协议、AI IDE工具了解
  • Bootstrap5 消息弹窗
  • 点云从入门到精通技术详解100篇-基于点云的三维多目标追踪与目标检测
  • android studio编译报错 Gradle
  • Linux驱动-块设备驱动
  • 前端快速入门——JavaScript变量、控制语句
  • 依靠视频设备轨迹回放平台EasyCVR构建视频监控,为幼教连锁园区安全护航
  • java设计模式-原型模式
  • DeepSeek 都开源了哪些技术?
  • 15. git push
  • 数据结构与算法分析:哈希表简述(一)
  • vue3项目跨域请求
  • 【C语言加油站】文件存储形式全解析:文本文件与二进制文件的本质区别
  • 【创新实训个人博客】prompt嵌入
  • linux shell looop循环写法
  • 回溯——固定套路 | 面试算法12道
  • 研究嵌入式软件架构时遇到的初始化堆栈溢出问题
  • 用Python爬虫抓取数据并保存为JSON的完整指南
  • GitHub 克隆/下载失败的解决方案
  • NOIP2011提高组.玛雅游戏
  • 【AAOS】【源码分析】CarAudioService(二)-- 功能介绍
  • 单旋翼无人机(直升机)和四旋翼无人机优势对比