Nodejs制作自定义中间件

对于Nodejs的中间件我想各位小伙伴都有所了解,下边我就以制作一个自定义的处理表单数据的中间件为例,告诉大家如何自作一个属于自己的自定义中间件。

1.创建一个util.js文件,用于封装编写自定义的表单数据处理中间件

// 导入querystring模块(目的是用于将下方拼接好的查询字符串转换成对象)
const qs = require('querystring')

//创建中间件处理函数
function bodyParser(req, res, next) {
  let str = ''
  // 这个chunk就是每次获取到的请求体的部分数据
  req.on('data', (chunk) => {
    str += chunk
  })

  req.on('end', () => {
    const body = qs.parse(str)
    //这里将处理好的请求体数据挂载到req上
    // 就是为了让后边的路由可以通过req.body获取到
    req.body = body
    next() //将流转关系传递给后边的中间件或路由
  })
}

//导出中间件函数
module.exports = bodyParser

2.创建一个app.js文件,用于创建服务,注册中间件

// 导入express模块
const express = require('express')

// 创建服务器对象
const app = express()

// 1.导入自定义的中间件模块
const bodyparser = require('./util.js')

// 2.注册自定义的中间件  将其注册为全局可用的中间件

app.use(bodyparser)

app.post('/test', (req, res) => {
  //由于全局注册过自定义的处理请求体表单数据的中间件,所以这里可以直接获取到请求体数据
  // 如果过没有注册过处理表单数据的中间件,这里req.body的返回值将会是undefined
  res.send(req.body)
})

//启动服务器
app.listen(80, () => {
  console.log('express server running at http://127.0.0.1');
})

3.效果测试

在集成终端中使用运行app.js文件,启动服务

打开postman,1.选择post请求方式,在地址栏输入http://127.0.0.1/test。2.选择Body选项。

3.选择x-www-form-urlendcoded 4.填写请求体表单数据 5.发送请求

由下图可见,在请求发送后,服务器端返回的就是请求体对象,说明自定义中间件生效

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值