自定义中间件

1.使用 app.use0来定义全局生效的中间件

// 导入 express 模块
const express = require('express')
// 创建 express的服务器实例
const app = express()
app.use(function(req, res, next) {// 中间件的业务逻辑
})

2.监听 req 的 data 事件

        在中间件中,需要监听 req 对象的 data 事件,来获取客户端发送到服务器的数据

        如果数据量比较大,无法一次性发送完毕,则客户端会把数据切割后分批发送到服务器。所以 data 事件可能会触发多次,每一次触发 data 事件时,获取到数据只是完整数据的一部分,需要手动对接收到的数据进行拼接。

app.use(function(req, res, next) {// 中间件的业务逻辑//定义变量,用来存储客户端发送过来的请求体数据let str = ''// 监听 req 对象的 data 件 (客户端发送过来的新的请求体数据)req.on('data',(chunk) => (拼接请求体数据,隐式转换为字符串str += chunk})
})

3.监听req 的end 事件

        当请求体数据接收完毕之后,会自动触发 req的end 事件

        因此,我们可以在 req 的 end 事件中,拿到并处理完整的请求体数据。示例代码如下:

app.use(function(req, res, next) {// 中间件的业务逻辑//定义变量,用来存储客户端发送过来的请求体数据let str = ''// 监听 req 对象的 data 件 (客户端发送过来的新的请求体数据)req.on('data',(chunk) => (拼接请求体数据,隐式转换为字符串str += chunk})// 监听 req 对象的 end 事件 (请求体发送完毕后自动触发)req.on( 'end', () => (// 打印完整的请求体数据console.log(str)// TODO: 把字符串格式的请求体数据,解析成对象格式})
})

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

        Node.js 内置了一个 querystring 模块,专门用来处理查询字符串。通过这个模块提供的 parse() 函数,可以轻松把查询字符串,解析成对象的格式。示例代码如下:

// 导入处理 querystring 的 Node.js 内置模块
const qs = require( 'querystring' )
app.use(function(req, res, next) {// 中间件的业务逻辑//定义变量,用来存储客户端发送过来的请求体数据let str = ''// 监听 req 对象的 data 件 (客户端发送过来的新的请求体数据)req.on('data',(chunk) => (拼接请求体数据,隐式转换为字符串str += chunk})// 监听 req 对象的 end 事件 (请求体发送完毕后自动触发)req.on( 'end', () => (// 打印完整的请求体数据// TODO: 把字符串格式的请求体数据,解析成对象格式// 调用 qs.parse() 方法,把查询字符串解析为对象const body = qs.parse(str)console.log(body)})
})

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

        上游中间件下游中间件及路由之间,共享同一份 req 和 res。因此,我们可以将解析出来的数据,挂载为 req的自定义属性,命名为 req.body,供下游使用。示例代码如下:

// 导入处理 querystring 的 Node.js 内置模块
const qs = require( 'querystring' )
app.use(function(req, res, next) {// 中间件的业务逻辑//定义变量,用来存储客户端发送过来的请求体数据let str = ''// 监听 req 对象的 data 件 (客户端发送过来的新的请求体数据)req.on('data',(chunk) => (拼接请求体数据,隐式转换为字符串str += chunk})// 监听 req 对象的 end 事件 (请求体发送完毕后自动触发)req.on( 'end', () => (// 打印完整的请求体数据// TODO: 把字符串格式的请求体数据,解析成对象格式// 调用 qs.parse() 方法,把查询字符串解析为对象const body = qs.parse(str)console.log(body)req.body = bodynext()})
})

6.将自定义中间件封装为模块

为了优化代码的结构,我们可以把自定义的中间件函数,封装为独立的模块,示例代码如下:

// middleware.js模块中的代码
const qs = require('querystring')
function bodyParser(req, res, next){ /*省略其它代码*/ }
module.exports = bodyParser // 向外导出解折请求体数据的中间件函数
// ---------------分割线--------------
//1,导入自定义的中间件模块
const myMiddleware = require( 'middleware' )
// 2,注朋自定义的中间件模块
app.use(myMiddleware)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/175443.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

03、K-means聚类实现步骤与基于K-means聚类的图像压缩

03、K-means聚类实现步骤与基于K-means聚类的图像压缩(1) K-means聚类实现步骤 开始学习机器学习啦,已经把吴恩达的课全部刷完了,现在开始熟悉一下复现代码。对这个手写数字实部比较感兴趣,作为入门的素材非常合适。…

理解Android无埋点技术

首先什么是无埋点呢,其实所谓无埋点就是开发者无需再对追踪点进行埋码,而是脱离代码,只需面对应用界面圈圈点点即可追加随时生效的事件数据点。 无埋点的好处 其实无埋点并不是完全不用写代码,而是尽可能的少写代码。开发者将SDK集…

英伟达GPU型号与架构介绍

1、AI驱动下,英伟达数据中心业务蓬勃发展 英伟达是GPU的发明创造者。1999年,英伟达在纳斯达克挂牌上市,并于同年提出了GPU概念,发布了GeForce 256。这被业界视为现代计算机图形技术的开端。 最初,GPU主要应用于PC游戏…

python的Re模块学习

本文初步介绍 正则表达式的定义,分类的组成部分。并举例编码 一、什么是正则表达式 答:在unix系统中,用来表示规则的字符串。在开发语言中需要处理大量的字符串,引入了这个规则。 字符串的处理: 1. 过滤字符串&…

力扣101. 对称二叉树

递归 思路: 克隆这棵树,递归比较左右子树互为镜像;终止条件为: 都为nullptr,则返回 true;有一个为 nullptr,则返回 false;(形状不一致)形状一致情况下&#…

零基础学编程轻松学编程,分享一款中文编程工具,编程构件简介

零基础学编程轻松学编程,分享一款中文编程工具,编程构件简介 中文编程开发语言工具编辑区界面截图如上图。 给大家分享一款中文编程工具 零基础轻松学编程,不需英语基础,编程工具可下载。 这款工具不但可以连接部分硬件&#…

数据库应用:Ubuntu 20.04 安装MongoDB

目录 一、理论 1.MongoDB 二、实验 1.Ubuntu 20.04 安装MongoDB 三、问题 1.Ubuntu Linux的apt 包管理器更新安装软件报错 2.Ubuntu20.04安装vim报错 3.Ubuntu20.04如何更换阿里源 4.Ubuntu22.04如何更换阿里源 一、理论 1.MongoDB (1)概念 …

6、Qt使用Log4Qt日志

一、知识点 1、Log4Qt有三部分 logger:负责捕获日志信息 layout:负责使用不同的样式输出日志 appender:负责输出信息到不同的目的地,比如数据库、文件、控制台等等 2、 日志级别如下,从上往下依次递增 ALL:…

Day34| Leetcode 1005. K 次取反后最大化的数组和 Leetcode 134. 加油站 Leetcode 135. 分发糖果

Leetcode 1005. K 次取反后最大化的数组和 题目链接 1005 K 次取反后最大化的数组和 本题目一开始我认为直接排序,让最小的取反回来就直接结束,我太天真了,一个反例直接猝死,下面上贪心的思路: 本题一共用到了两个贪…

css之svg 制作圆及旋转

1.代码 <template><div class"loading-box"><div class"circle-container"><svg width"75" height"75" class"move-left-to-right"><circle cx"37.5" cy"37.5" r"26&…

高端影像仪:打破微小产品测量局限

在现代工业生产中&#xff0c;影像仪以CCD数位影像为基石&#xff0c;将计算机屏幕测量技术与空间几何运算的能力融为一体&#xff0c;可以用于测量微小产品的各种尺寸和形状&#xff0c;为生产过程中的质量控制提供重要的参考依据。 影像仪产品内置高精度光学电动双倍镜头&am…

什么是动态住宅IP?它有什么用途?

随着网络的迅速发展&#xff0c;许多人对代理IP已经有了比较深刻的认识&#xff0c;并且广泛地运用到了各自的业务中&#xff0c;尤其在跨境的相关业务中表现尤其卓越。对于代理IP的类别&#xff0c;也需要根据自己的业务类型具体选择最合适的&#xff0c;那么今天IPFoxy就给大…

网页设计--第5次课后作业

1、快速学习JavaScript的基本知识第1-10章 JavaScript入门 - 绿叶学习网 2、使用所学的知识完成以下练习。需求如下3个&#xff1a; 1&#xff09;点亮灯泡 2&#xff09;将所有的div标签的标签体内容后面加上&#xff1a; very good 3&#xff09;使所有的复选框呈现被选…

【javaWeb】HTTP协议

HTTP (全称为 “超文本传输协议”) 是一种应用非常广泛的应用层协议 HTTP 是一个文本格式的协议. 可以通过 Chrome 开发者工具或者 Fiddler 抓包, 分析 HTTP 请求/响应的细节. 上图是通过Fiddler对访问百度搜索页时抓取的一个http协议的包。 观察抓包结果,可以看到,当前 http…

myAGV 2023 Pi 全新升级!

Introduction 在高速发展的自动化和机器人技术领域&#xff0c;我们的公司一直致力于提供高效、灵活且可靠的轻量级机械臂解决方案。然而&#xff0c;我们也深知&#xff0c;传统的机械臂需要固定在一个地方&#xff0c;这在一定程度上限制了其在空间上的应用范围。为了突破这一…

【论文阅读】ActiveNeRF:通过不确定性估计候选新视图

【论文阅读】ActiveNeRF: Learning where to See with Uncertainty Estimation Abstract1 Introduction3 Background4 NeRF with Uncertainty Estimation5 ActiveNeRF5.1 Prior and Posterior Distribution5.2 Acquisition Function5.3 Optimization and Inference 6 Experimen…

ECharts配置项手册了解及使用

1&#xff1a;点击文档然后选择配置项手册或者&#xff1a;Documentation - Apache ECharts 2&#xff1a;

中间件安全:Weblogic 漏洞.(使用工具可以利用多种类型漏洞)

中间件安全&#xff1a;Weblogic 漏洞.&#xff08;使用工具可以利用多种类型漏洞&#xff09; WebLogic 是美国 Oracle 公司出品的一个 application server&#xff0c;确切的说是一个基于 JAVA EE 架构的中间件&#xff0c;WebLogic 是用于开发、集成、部署和管理大型分布式…

达梦数据库ddl锁等待时间太短?解决方法

在日常工作中&#xff0c;一般不会允许停业务来进行DDL维护操作&#xff0c;因为停止业务的代价会比较高&#xff0c;对于复杂的系统&#xff0c;停机维护更是充满了不可控的隐患和危险。DM数据库可以采用延长锁超时的时间&#xff0c;以及开启快速加列、修改列、删除列提高DDL…

亚信科技AntDB数据库与库瀚存储方案完成兼容性互认证

近日&#xff0c;亚信科技AntDB数据库与苏州库瀚信息科技有限公司自主研发的RISC-V数据库存储解决方案进行了产品兼容测试。经过双方团队的严格测试&#xff0c;亚信科技AntDB数据库与库瀚数据库存储解决方案完全兼容、运行稳定。除高可用性测试外&#xff0c;双方进一步开展TP…