nodejs中间件

2 中间件的概念

2.1 什么是中间件

中间件(middleware)特指业务流程的中间处理环节

2.2 中间件的调用流程

当一个请求到达 Express 的服务器之后,可以连续调用多个中间件,从而对这次请求进行预处理

2.3 Express 中间件的格式

本质上是一个 function 处理函数

中间件函数的形参列表中,必须包含 next 参数,而路由处理函数只包含 req 和 res

next 函数是实现多个中间件连续调用的关键,它表示将流转关系流转给下一个中间件或者路由

3 express 中间件

3.1 定义中间件函数

复制代码
// 定义一个最简单的中间件函数
const mw = (req, res, next) => {
  console.log('这是最简单的中间件函数');
  // 把流转关系,转交给下一个中间件或者路由
  next()
}

3.2 全局生效的中间件

客户端发起的任何请求,到达服务器之后都会触发的中间件,叫做全局生效中间件

通过调用 app.use(中间件函数),即可定义一个全局生效的中间件

app.use(mw)

1

3.3 局部生效的中间件

不使用 app.use() 定义的中间件,叫做局部生效的中间件

app.get('/user', mw, (req, res) => {})

1

3.4 中间件使用注意事项

除错误级别中间件外,其他类型中间件一定要在路由之前注册

客户端发送过来的请求,可以连续调用多个中间件进行处理

执行完中间件的业务代码之后,不要忘记调用 next() 函数

为了防止代码逻辑混乱,调用 next() 函数后不要再写额外的代码

连续调用多个中间件时,多个中问件之间,共享 req 和 res 对象

3.5 中间件的分类

为了方便大家理解和记忆中间件的使用,Express 官方把常见的中间件用法,分成了5大类,分别是:

应用级别的中间件

通过 app.use() 、 app.get() 、 app.post() ,绑定到 app 实例上的中间件

// 应用级别的中间件(全局中间件)

app.use((req, res, next) => {

next()

})

// 应用级别的中间件(局部中间件)

app.get('/', mw, (req, res) => {

res.send('Hone Npage.')

})

路由级别的中间件

绑定到 express.Router() 上的中间件

const app = express()

const router = express.Router()

// 路由级别的中间件

router.use(function (req, res, next) {

console.log( "Time:" Date.now())

next()

})

app.use(router)

1

2

3

4

5

6

7

8

错误级别的中间件

作用:专门用来捕获整个项目中发生的异常错误,从而防止项目异常崩溃的问题

格式:错误级别中间件的 function 处理函数中,必须有 4 个形参,形参顺序从前到后,分别是 (err, req, res, next)

app.get('/', (req, res) => {

throw new Error('服务器发生错误')

res.send('Home Page')

})

app.use((err, req, res, next) => {

console.log('发生了错误!', err.message);

res.send(`发生了错误!${err.message}`)

})

Express 内置的中间件

express.static() :快速托管静态资源

express.json() :解析 JSON 格式的请求数据

express.urlencoded() :解析 URL-encoded 格式的请求数据

第三方的中间件

非 express 官方提供的,而是由第三方开发出来的中间件

4 自定义中间件

自己手动模拟一个类似于 express.urlencoded 这样的中间件,来解析 POST 提交到服务器的表单数据

实现步骤:定义中间件

监听 req 的 data 事件

监听 req 的 end 事件

使用 querystring 模块解析请求体数据

将解析出来的数据对象挂载为 req.body

将自定义中间件封装成模块

javascript 复制代码
custom-bodyparser.js

const qs = require('querystring') 

const bodyParser = (req, res, next) => {
  let str = ''
  req.on('data', (chunk) => {
    str += chunk
  })
  req.on('end', () => {
    req.body = qs.parse(str)
    next()
  })
}

module.exports = bodyParser

index.js

const express = require('express')
const bodyParser = require('./custom-bodyparser') 
const app = express()

app.use(bodyParser)

app.post('/user', (req, res) => {
  res.send(req.body)
})

app.listen(80, () => {
  console.log('http://127.0.0.1');
})
相关推荐
lingggggaaaa8 小时前
小迪安全v2023学习笔记(七十九讲)—— 中间件安全&IIS&Apache&Tomcat&Nginx&CVE
笔记·学习·安全·web安全·网络安全·中间件·apache
利白17 小时前
iceoryx高性能进程间通信中间件,在Windows环境的编译教程
中间件·内存·进程通信·ipc·iceoryx
小红帽2.01 天前
GOFLY开源客服系统-处理gin框架下的session中间件
中间件·gin
Ray Song1 天前
MCAP :机器人数据容器的全面实践指南
中间件·自动驾驶·dds·mcap
Ray Song2 天前
【FastDDS】Layer Transport ( 05-Shared Memory Transport)
中间件·自动驾驶·dds·fastdds
北执南念2 天前
数据库中间件ShardingSphere v5.2.1
数据库·中间件
红鼻子时代2 天前
Day5-中间件与请求处理
中间件·fastapi·后端开发
只因在人海中多看了你一眼2 天前
B.50.10.01-消息队列与电商应用
中间件
子非鱼@Itfuture2 天前
【Kafka】Kafka使用场景用例&Kafka用例图
分布式·中间件·kafka
中国胖子风清扬2 天前
Rust 序列化技术全解析:从基础到实战
开发语言·c++·spring boot·vscode·后端·中间件·rust