中间件

  客户端的请求到达服务器时,他的生命周期是:request -- 服务器端处理 -- 响应

  在服务器端处理过程中,业务逻辑复杂时,为了便于开发维护,需要把处理的事情分成几步,这里每一步就是一个中间件,数据就是中间件的操作对象。

定义:中间件就是一个处理函数;只不过这个函数比较特殊,包含了三个参数,分别是 reqresnext

注意:中间件方法中的三个参数:

  • req:请求对象;

  • res:响应对象;

  • next:next是一个函数,next()可以被调用,表示调用下一个中间件方法;

function(req,res,next){
//...我们自己的逻辑
next();
}

app.use(myrFunc) 要写在下面两句的前面

app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));

是因为路由后或请求静态资源后,一次请求响应的生命周期实质上已经结束,加在这后面进行请求处理,没有任何意义。

app.use()就是加载中间件的

测试:

const express = require('express')

const app = express()

// 创建第一个中间件
app.use(function(req, res, next) {
console.log('第一个中间件')
req.a = 'aaa'
next()
}) // 创建第二个中间件 不写 next(),那么后面注册的函数就不会执行,
app.use(function(req, res, next) {
console.log('第二个中间件')
res.b = 'bbb'
next()
}) // 创建第三个中间件
app.use(function(req, res, next) {
console.log('第三个中间件')
console.log(req.a)
console.log(res.b)
// 结束中间件的调用
res.send('结束中间件的调用')
}) app.listen(3001, function() {
console.log('Express server is running at http://127.0.0.1:3001')
})

Express 框架中对中间件的5种分类

  • 应用级别的中间件: 挂载到 app 上的中间件 app.get('URL地址', (req, res, next)=> {})

  • 路由级别的中间件: 挂载到 router 对象上的中间件 router.get('url地址', (req, res, next)=>{})

  • 错误级别的中间件: 回调函数中,有四个参数 app.use((err, req, res, next)=>{})

  • 唯一内置的中间件: express.static()

  • 第三方中间件: 非express框架提供的,需要程序员手动安装才能使用的中间件;body-parser 解析post 表单数据

使用第三方body-parser

const express = require('express')

const app = express()

// 导入解析表单数据的中间件
const bodyParser = require('body-parser')
// 把导入的第三方中间安装到app身上
app.use(bodyParser.urlencoded({extended: false })) // app.use 就是注册安装中间件 app.post('/adduser', (req, res) => {
// req.body 上存放的,就是通过 body-parser 解析出来的表单数据
res.json(req.body)
}) app.listen(3001, function() {
console.log('Express server is running at http://127.0.0.1:3001')
})

自己模拟中间件

const express = require('express')

const app = express()

const myBodyparse = require('./04myBodyparse')
// 专门定义一个解析表单数据的中间件
app.use(myBodyparse) app.post('/adduser', (req, res) => {
res.send(req.body)
}) app.post('/updateuser', (req, res) => {
res.send(req.body)
}) app.listen(3001, function() {
console.log('Express server is running at http://127.0.0.1:3001')
})

04myBodyparse.js

const qs = require('querystring')

module.exports = function(req, res, next) {
let dtStr = ''
// 只要有数据到达服务器,就会触发 data
req.on('data', chunk => {
dtStr += chunk
})
// 只要触发了 end 事件,就证明数据发送和接收完毕了
req.on('end', () => {
const result = qs.parse(dtStr)
req.body = result
console.log(req.body)
next()
})
}

nodejs(12)Express 中间件middleware的更多相关文章

  1. nodejs之express中间件路由使用

    1.express 中间件使用 /* * 中间件:就是匹配路由之前和匹配路由之后做的一系列操作 */ var express = require('express'); var app = new e ...

  2. nodejs之express中间件cookie-parser使用

    知识点: * .domain的使用,.aaa.com的域名都共享这个cookie信息 * res.cookie(,domain:'.aaa.com'}); * .获取所有cookie,设置cookie ...

  3. nodeJs,Express中间件是什么与常见中间件

    中间件的功能和分类 中间件的本质就是一个函数,在收到请求和返回相应的过程中做一些我们想做的事情.Express文档中对它的作用是这么描述的: 执行任何代码.修改请求和响应对象.终结请求-响应循环.调用 ...

  4. nodejs之express中间件body-parser使用

    1.安装express和body-parser npm install express npm install body-parser 2‘.案例如下 var express = require('e ...

  5. 77.深入理解nodejs中Express的中间件

    转自:https://blog.csdn.net/huang100qi/article/details/80220012 Express是一个基于Node.js平台的web应用开发框架,在Node.j ...

  6. 【nodejs原理&源码赏析(1)】Express中间件系统的基本实现

    一直觉得express的中间件系统这种流式处理非常形象,就好像加工流水线一样,每个环节都在针对同一个产品的不同部分完成自己的工作,最后得到一个成品.今天就来实现一个简易的[中间件队列]. 一. API ...

  7. express中的中间件(middleware)、自定义中间件、静态文件中间件、路由中间件

    express文档地址 什么是中间件呢(middleware)?它是谁的中间件呢? 首先我们需要了解到请求和响应, 请求就是客户端发送请求给服务器, 响应就是,服务器根据客户端的请求返回给客户端的数据 ...

  8. nodejs之express的中间件

    express中间件分成三种 内置中间件 static 自定义中间件 第三方中间件 (body-parser) (拦截器) 全局自定义中间件 在请求接口时 有几个接口都要验证传来的内容是否存在或者是否 ...

  9. nodejs之express的使用

    Express是目前最流行的基于Node.js的Web开发框架,可以快速的搭建一个完整功能的网站. Express框架建立在内置的http模块上,http模块生成服务器的原始代码如下. var htt ...

随机推荐

  1. Spring Boot Web 开发@Controller @RestController 使用教程

    在 Spring Boot 中,@Controller 注解是专门用于处理 Http 请求处理的,是以 MVC 为核心的设计思想的控制层.@RestController 则是 @Controller ...

  2. ARG 构建参数----Dockerfle文件的重用

    ARG 构建参数----Dockerfle文件的重用 格式:ARG <参数名>[=<默认值>] 构建参数和 ENV 的效果一样,都是设置环境变量. 所不同的是,ARG 所设置的 ...

  3. 转专业后补修C语言的一些体会(3)

    1.指针:指针是C语言最为强大的工具之一,有着很多优点,比如可以改善子程序的效率,为动态数据结构提供支持,为C的动态内存分配系统提供支持,为函数提供修改变量值的手段.但指针的使用十分困难.会出现很多意 ...

  4. 对于java中反编译命令的使用以及Integer包装类的查看

    Integer是基于int的包装类 我们可以用测试代码来看看Integer类是如何实现装箱和拆箱的 public class BoxAndUnbox { /** * @param args */ pu ...

  5. 【原】linux两台服务器之间免密登录方法

    搭建集群机器192.168.0.100和192.168.0.200里,需要两台机器中间相互拷贝文件: 方式一:下载192.168.0.100机器文件到本地,再将本地文件拷贝到B机器 方式二:192.1 ...

  6. PHPStorm 使用 Xdebug

    一.下载xdebug xdebug官网:https://xdebug.org/download.php 在选择下载哪个版本的xdebug的时候需要注意了,下面有两种方法,让你准确的下载自己环境对应的x ...

  7. 洛谷 P5057 [CQOI2006]简单题(树状数组)

    嗯... 题目链接:https://www.luogu.org/problem/P5057 首先发现这道题中只有0和1,所以肯定与二进制有关.然后发现这道题需要支持区间更改和单点查询操作,所以首先想到 ...

  8. nginx 重写 隐藏index.php

    修改 nginx.conf 文件location / { if (!-e $request_filename) { rewrite ^(.*)$ /index.php?s=$1 last; break ...

  9. HTML5中新增的主体结构元素

    article元素 article元素代表文档.页面或应用程序中独立的.完整的.可以独自被外部引用的内容. 它可以使一篇博客或者报刊中的文章,一篇论坛帖子.一段用户评论或独立的插件,或其他任何独立的内 ...

  10. Matlab的简单数据保存读取

    1.使用load进行文件读取 例如读入文件名为'filename.txt'中的数据,那么可以使用以下代码: load('filename.txt') 注意:filename.txt中的数据应符合矩阵形 ...