中间件函数

简介: 【5月更文挑战第18天】

image.png
中间件函数(Middleware Function)在多种编程上下文和框架中都存在,但最常被提及的可能是与Express.js(一个流行的Node.js web框架)相关的中间件。中间件函数是一种用于处理HTTP请求和响应的函数,它们可以在请求被发送到最终的处理程序(如路由处理程序)之前或之后执行特定的任务。

在Express.js中,中间件函数通常有以下特征:

  1. 接收三个参数req(请求对象),res(响应对象),以及一个next函数。
  2. 异步性:中间件函数可以是同步的,也可以是异步的(使用回调函数、Promises或async/await)。
  3. 可堆叠:多个中间件函数可以按照特定的顺序堆叠在一起,形成一个中间件堆栈。
  4. 调用next()函数:中间件函数可以调用next()函数来将控制权传递给堆栈中的下一个中间件函数。如果当前中间件函数没有调用next(),那么请求-响应周期就会在此处停止。

下面是一个简单的Express.js中间件函数的示例:

const express = require('express');
const app = express();

// 这是一个中间件函数
app.use((req, res, next) => {
   
   
  console.log('Time:', Date.now());

  // 在继续之前,添加一个自定义的请求头
  req.requestTime = Date.now();

  // 调用 next() 以将控制权传递给下一个中间件
  next();
});

// 另一个中间件函数,只处理GET请求
app.use((req, res, next) => {
   
   
  if (req.method !== 'GET') {
   
   
    // 如果不是GET请求,停止处理并返回405错误
    res.status(405).send('Method Not Allowed: GET');
  } else {
   
   
    // 否则,继续处理
    next();
  }
});

// 路由处理程序
app.get('/', (req, res) => {
   
   
  res.send('Hello from Express!');
  console.log('Request Time:', req.requestTime);
});

app.listen(3000, () => console.log('Server started on port 3000'));

在这个示例中,我们定义了两个中间件函数和一个路由处理程序。第一个中间件函数简单地记录请求的时间,并在请求对象上添加一个自定义属性。第二个中间件函数检查请求的方法,如果不是GET请求,则返回一个错误;否则,它将控制权传递给下一个中间件(在这种情况下是路由处理程序)。路由处理程序最后发送一个响应。

目录
相关文章
|
7月前
|
前端开发 中间件
Nestjs(四)中间件常见使用方式(class、函数中间件)
Nestjs(四)中间件常见使用方式(class、函数中间件)
137 5
|
7月前
|
JavaScript 中间件 API
中间件使用异步函数
【5月更文挑战第16天】中间件使用异步函数
46 4
|
7月前
|
消息中间件 存储 负载均衡
消息中间件的选择:RabbitMQ是一个明智的选择
消息中间件的选择:RabbitMQ是一个明智的选择
120 0
|
6月前
|
消息中间件 存储 中间件
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
【消息中间件】详解三大MQ:RabbitMQ、RocketMQ、Kafka
1646 0
|
5月前
|
消息中间件 编解码 Docker
Docker部署RabbitMQ消息中间件
【7月更文挑战第4天】Docker部署RabbitMQ消息中间件
281 3
|
2月前
|
消息中间件 编解码 Docker
【Docker项目实战】Docker部署RabbitMQ消息中间件
【10月更文挑战第8天】Docker部署RabbitMQ消息中间件
122 1
【Docker项目实战】Docker部署RabbitMQ消息中间件
|
4月前
|
消息中间件 Java 测试技术
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
这篇文章是关于如何在SpringBoot应用中整合RabbitMQ的消息中间件。内容包括了在SpringBoot项目中添加RabbitMQ的依赖、配置文件设置、启动类注解,以及如何通过单元测试来创建交换器、队列、绑定,并发送和接收消息。文章还介绍了如何配置消息转换器以支持对象的序列化和反序列化,以及如何使用注解`@RabbitListener`来接收消息。
消息中间件RabbitMQ---SpringBoot整合RabbitMQ【三】
|
4月前
|
消息中间件 Docker 容器
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
这篇文章提供了RabbitMQ的安装和基本使用教程,包括如何使用Docker拉取RabbitMQ镜像、创建容器、通过浏览器访问管理界面,以及如何创建交换机、队列、绑定和使用direct、fanout和topic三种类型的交换器进行消息发布和接收的测试。
消息中间件RabbitMQ---Docker安装RabbitMQ、以及RabbitMQ的基本使用【二】
|
4月前
|
消息中间件 存储 网络协议
消息中间件RabbitMQ---概述和概念 【一】
该文章提供了对消息中间件RabbitMQ的全面概述,包括其核心概念、工作原理以及与AMQP和JMS的关系。
消息中间件RabbitMQ---概述和概念 【一】
|
5月前
|
消息中间件 监控 负载均衡
中间件RabbitMQ性能瓶颈
【7月更文挑战第13天】
329 11