nodejs(这指express) 中间件

铺垫

一个请求发送到服务器,要经历一个生命周期,服务端要: 监听请求-解析请求-响应请求,服务器在处理这一过程的时候,有时候就很复杂了,将这些复杂的业务拆开成一个个子部分,子部分就是一个个中间件。对于处理请求来说,在响应发出之前,可以对请求和该级响应做一些操作,并且可以将这个处理结果传递给下一个处理步骤

express 这样描述中间件的:

执行任何代码。

修改请求和响应对象。

终结请求-响应循环。

调用堆栈中的下一个中间件

分类

应用级中间件

路由级中间件

错误处理中间件

内置中间件

第三方中间件

举个栗子:

 var express = require('express');
var app = express();
app.get('/', function(req, res, next) {
// req 修改请求
// res 响应对象
next(); // 当前中间件函数没有结束请求/响应循环, 调用next(),
// 将控制权传递给下一个中间件函数继续往下处理,否则页面到此会被挂起
});
app.get('/end', function(req, res) {
res.send('程序到我这里就结束了,没有next方法');
})
app.listen(3000);

上面next()的说明: next()函数不是nodejs或者express的函数,而是传递中间件函数的第三变量,它是一个统称,可以为任意名称,为了名称统一,不造成混淆,约定为next(),调用它之后会将调用应用程序中的下一个中间件程序

中间件的使用说明:

 var express = require('express');
var app = express();
app.use(requestTime); //
var requestTime = function(req,res, next) {
req.requestTime = new Date().getTime();
next();
} app.get('/time', function(req, res, next) {
var timeText = '当前时间为:';
timeText = timeText + req.requestTime; // 这里的req.requestTime 是上一个中间件函数传递过来的,
// 一个业务处理流程,多个中间件函数对请求 req进行修改处理,并且通过next() 传递给下一个中间件函数,
// 这样下面的中间件函数都能拿到上一个中间件函数处理的结果
res.send(timeText);
});
app.get('/end', function(req, res) {
res.send('程序到我这里就结束了,没有next方法');
})
app.listen(3000);

下面是多个中间件函数,在各自函数中处理请求和响应的例子:

具体

var express = require('express');
var app = express(); var middleA = function (req, res, next) {
req.useOne = '应用程序经过了 middleA ';
res.useOne = 'middleA 处理后的数据 middleA';
req.paramasQuery = 1
// console.log(req.useOne, req.useTwo, req.useThree);
next();
} var middleB = function (req, res, next) {
req.useTwo = '应用程序又经过了 middleB';
res.useTwo = 'middleB 处理后的数据 middleB';
req.paramasQuery += 1;
console.log(res.useOne, res.useTwo, res.useThree);
next();
} var middleC = function (req, res, next) {
req.useThree = '应用程序又经过了 middleC';
res.useThree = 'middleC 处理后的数据 middleC';
req.paramasQuery += 2;
console.log(res.useOne, res.useTwo, res.useThree);
console.log(req.paramasQuery);
next();
}
app.use(middleA);
app.use(middleB);
app.use(middleC); app.get('/', function(req, res, next) {
console.log(req.useOne, req.useTwo, req.useThree);
// 应用程序经过了 middleA 应用程序又经过了 middleB 应用程序又经过了 middleC
// 上面的req里面的参数就是在 不同的中间件函数中处理出来的
console.log(res.useOne, res.useTwo, res.useThree);
// middleA 处理后的数据 middleA middleB 处理后的数据 middleB middleC 处理后的数据 middleC
// 上面的res的响应参数也是在上面一个个中间件的响应res中逐步处理 累加而得
req.paramasQuery += 3;
// req中paramasQuery的参数经过中间不同的中间件函数处理,已经累加到7,
// 同理对于res 采用相同的处理方式,也可以达到这样的效果
// 我们以此可以推出,如果处理一个很复杂的程序时,我们一个中间件函数只处理一个步骤,
// 并且可以把该步骤处理后的结果,传递给下一个中间件函数处理,
// 一种流水线的处理方式,职责专一,效率很快
res.send('req.paramasQuery 经过不同的中间件处理后的结果是:' + req.paramasQuery); // 7
}) app.listen(5000, function() {
console.log('5000 端口启动了')
})

总结:

express 中间件函数,帮助拆解主程序的业务逻辑,并且每一个的中间件函数处理的结果都会传递给下一个中间件函数。想象一下工厂上流水线工人,在清洗一个箱子的一个场景。
第一个人清洗侧面,第二个人清洗底面,第三个人清洗顶面,。。。,这条流水线结束后,箱子也就清洗干净了。
各做各的,不相互影响,又彼此协作。

express 中间件的理解的更多相关文章

  1. express中间件的理解

    参考 :https://blog.csdn.net/huang100qi/article/details/80220012 Express中间件分为三种内置中间件.自定义中间件.第三方中间件 可以与n ...

  2. 理解Express 中间件

    Express 中间件 Express程序基本上是一系列中间件函数的调用.中间件就是一个函数, 接受 req.res.next几个参数. 中间件函数可以执行任何代码, 对请求和响应对象进行修改, 结束 ...

  3. Express中间件的意思 next()的方法

    一.什么是express?Express是一个简洁.灵活的noode.jsWeb应用开发框架,它提供一系列强大的特性,帮助你创建各种Web和移动设备应用.Express项目的底层由许多的中间件在协同工 ...

  4. Express中间件的原理及实现

    在Node开发中免不了要使用框架,比如express.koa.koa2拿使用的最多的express来举例子开发中肯定会用到很多类似于下面的这种代码 var express = require('exp ...

  5. 浅析express以及express中间件

    一.express: 1.express: Express是什么? Express是基于node.js平台的web应用开发框架: 作用:可以实现快速搭建骨架: 优点:开发web应用更加方便,更加快捷. ...

  6. Express中间件简单的实现原理

    上一篇理解Express的使用之后, 再总结一篇Express中间件的简单实现原理. 我们知道Express中间件就是一个个的函数, 那么怎么让这些函数有序的执行呢? 那就需要我们调用 next 函数 ...

  7. express 中间件的简单应用与实现

    express 中间件的简单应用与实现 看了慕课网双越老师的课之后结合自己的理解做了一些简单的总结,如有不恰当之处,欢迎指正. 提到 express 就不得不提到中间件,接下来就简单的介绍一下 exp ...

  8. Express中间件原理详解

    前言 Express和Koa是目前最主流的基于node的web开发框架,他们的开发者是同一班人马.貌似现在Koa更加流行,但是仍然有大量的项目在使用Express,所以我想通过这篇文章说说Expres ...

  9. Node.js连接Mysql,并把连接集成进Express中间件中

    引言 在node.js连接mysql的过程,我们通常有两种连接方法,普通连接和连接池. 这两种方法较为常见,当我们使用express框架时还会选择使用中间express-myconnection,可以 ...

随机推荐

  1. axios 提交 application/x-www-form-urlencoded

    最近工作比较忙 , 喜欢上了用有道云做笔记 , 写博客就是为了记录自己的学习的点点滴滴 , 如果能对其他人有帮助当然最好了 , 我一定要将这个习惯进行下去 .. ..... 我们以前的前后交互方式一般 ...

  2. js父窗体关闭,子窗体紧随

    近来的.我们遇到了权限管理系统.由于权限管理系统与原系统的风格不符.打开一个全新的窗口.问题就来了.admin取消后,,权限管理形式不关闭.其他普通用户登录后.尚能经营权的管理形式. 简化问题:adm ...

  3. Cocos2d-x3.1下实现相似iOS页面滑动指示圆点

    原文地址:http://blog.csdn.net/qqmcy/article/details/37612457 代码下载:http://download.csdn.net/detail/qqmcy/ ...

  4. 《Silk》(皇家律师)—— 英美海洋法系

    Abortion Act:堕胎法: 1. 表达习惯 we employ him, not the other way round, Officially,-,官方的说法是,Unofficially,- ...

  5. BigTable读后笔记

    BigTable读后笔记 GFS可能出现重复记录或者padding,Bigtable如何处理这种情况使得对外提供强一致性模型? ANS: Bigtable写入GFS的数据分为两种: 1)操作日志,当T ...

  6. linux_ linux下查看最消耗CPU、内存的进程 20

    1.CPU占用最多的前10个进程: ps auxw|head -1;ps auxw|sort -rn -k3|head -10 2.内存消耗最多的前10个进程 ps auxw|head -1;ps a ...

  7. 潜移默化学会WPF(转载篇)--屏幕显示Label,鼠标移上去变成textBox

    原文:潜移默化学会WPF(转载篇)--屏幕显示Label,鼠标移上去变成textBox <Window x:Class="WpfApplication1.Window1" x ...

  8. SQL Server数据库碎片整理

    碎片产生   在SQL Server中,存储数据的最小单位是页,每一页所能容纳的数据为8060字节.而页的组织方式是通过B树结构  SQL Server向每个页内存储数据的最小单位是表的行(Row)  ...

  9. Visual Studio 2015 和 Apache Cordova 跨平台开发入门

    原文:Visual Studio 2015 和 Apache Cordova 跨平台开发入门(一) 基于 Windows 10 的 Visual Studio 2015 跨平台的应用开发主要分为基于V ...

  10. Substring详解

    class Program { static void Main(string[] args) { string str = "Hello World!"; ; //Substri ...