一、中间件

从字面意思,我们可以了解到它大概就是做中间代理操作,事实也是如此;大多数情况下,中间件就是在做接收到请求和发送响应中间的一系列操作。事实上,express是一个路由和中间件的web框架,Express 应用程序基本上是一系列中间件函数的调用。

中间件函数可以执行以下任务:
执行任何代码。
对请求和响应对象进行更改。
结束请求/响应循环。
调用堆栈中的下一个中间件函数。

中间件也分为应用层中间件、路由中间件、内置中间件、错误处理中间件和第三方中间件。下面分别对以下进行说明:

1.应用层中间件

应用级中间键绑定到app对象使用app.use和app.METHOD()-需要处理http请求的方法,例如GET、PUT、POST,将之前的get或者post替换为use就行。
例如下面实例:

const express=require("express");var app=express();//匹配路由之前的操作
app.use(function(req,res){console.log("访问之前");
});app.get("/",function(req,res){res.send("主页");
});app.listen(8080);

这时我们会发现http://localhost:8080/地址一直在加载,但命令行里显示了“访问之前”,说明程序并不会同步执行,如果使用next来是路由继续向下匹配,那么就能又得到主页数据了:

const express=require("express");var app=express();//匹配路由之前的操作
app.use(function(req,res,next){console.log("访问之前");next();
});app.get("/",function(req,res){res.send("主页");
});app.listen(8080);

  当然也可以简化写法:

const express=require("express");var app=express();app.use(function(req,res,next){console.log("访问之前");next();
},function(req,res){res.send("主页");
});app.listen(8080);

  因此,在进行路由匹配之前或再录又要继续向下执行时想做个操作,那么应用层中间件无疑是好的选择。

2.路由中间件

路由级中间件和应用级中间件类似,只不过他需要绑定express.Router();

var router = express.Router()

  在匹配路由时,我们使用 router.use() 或 router.VERB() ,路由中间件结合多次callback可用于用户登录及用户状态检测。

const express = require("express");
var app = express();
var router=express.Router();router.use("/",function(req,res,next){console.log("匹配前");next();
});router.use("/user",function(req,res,next){console.log("匹配地址:",req.originalUrl);next();
},function(req,res){res.send("用户登录");
});app.use("/",router);app.listen(8080);

  总之在检测用户登录和引导用户应该访问哪个页面是,路由中间件绝对好用。

3.错误处理中间件

顾名思义,它是指当我们匹配不到路由时所执行的操作。错误处理中间件和其他中间件基本一样,只不过其需要开发者提供4个自变量参数。

app.use((err, req, res, next) => {res.sendStatus(err.httpStatusCode).json(err);
});

  一般情况下,我们把错误处理放在最下面,这样我们即可对错误进行集中处理。

const express=require("express");var app=express();app.get("/",function(req,res,next){const err=new Error('Not Found');res.send("主页");next(err);
});app.use("/user",function(err,req,res,next){console.log("用户登录");next(err);
},function(req,res,next){res.send("用户登录");next();
});app.use(function(req,res){res.status(404).send("未找到指定页面");
});app.listen(8080);

  

4.内置中间件

从版本4.x开始,Express不再依赖Content,也就是说Express以前的内置中间件作为单独模块,express.static是Express的唯一内置中间件。

express.static(root, [options]);

  通过express.static我们可以指定要加载的静态资源。root代表加载静态资源的路径,options作为可选参数拥有一下属性:

属性 描述 类型 缺省值
dotfiles 是否对外输出文件名以点(.)开头的文件。有效值包括“allow”、“deny”和“ignore” 字符串 “ignore”
etag 启用或禁用 etag 生成 布尔 true
extensions 用于设置后备文件扩展名。 数组 []
index 发送目录索引文件。设置为 false 可禁用建立目录索引。 混合 “index.html”
lastModified 将 Last-Modified 的头设置为操作系统上该文件的上次修改日期。有效值包括 true 或 false。 布尔 true
maxAge 设置 Cache-Control 头的 max-age 属性(以毫秒或者 ms 格式中的字符串为单位) 数字 0
redirect 当路径名是目录时重定向到结尾的“/”。 布尔  
setHeaders 用于设置随文件一起提供的 HTTP 头的函数。 函数 true

以下示例将使用了 express.static 中间件,并且提供了一个详细的’options’对象(作为示例):

var options = {dotfiles: 'ignore',etag: false,extensions: ['htm', 'html'],index: false,maxAge: '1d',redirect: false,setHeaders: function (res, path, stat) {res.set('x-timestamp', Date.now());}
}app.use(express.static('public', options));

5.第三方中间件

形如之前我们的body-parser,采用引入外部模块的方式来获得更多的应用操作。如后期的cookie和session。

var express = require('express');
var app = express();
var cookieParser = require('cookie-parser');

  以上就是关于express中间件类型,在实际项目中,中间件都是必不可少的,因此熟悉使用各种中间件会加快项目的开发效率。

转载于:https://www.cnblogs.com/lpxj-blog/p/10713496.html

Express全系列教程之(五):Express的中间件相关推荐

  1. Express全系列教程之(十五):文件下载

    简介 文件下载非常简单,仅需通过res.download()执行即可,他可以写为3种形式: res.download('/report-12345.pdf');res.download('/repor ...

  2. Express全系列教程之(十):jade模板引擎

    一.前言 随着前端业务的不断发展,页面交互逻辑的不断提高,让数据和界面实现分离渐渐被提了出来.JavaScript的MVC思想也流行了起来,在这种背景下,基于node.js的模板引擎也随之出现. 什么 ...

  3. Express全系列教程之(四):获取Post参数的两种方式

    一.关于POST请求 post方法作为http请求很重要的一部分,几乎所有的网站都有用到它,与get不同,post请求更像是在服务器上做修改操作,它一般用于数据资源的更新. 相比于get请求,post ...

  4. OpenCV学习系列教程第五篇:测试和提高代码的效率

    Opencv-Python学习系列教程第五篇 来自opencv-python官方学习文档,本人谨做翻译和注释,以及一些自己的理解 本文由作者翻译并进行代码验证,转载请注明出处~ 官方文档请参阅:htt ...

  5. Java NIO系列教程(五) 通道之间的数据传输

    在Java NIO中,如果两个通道中有一个是FileChannel,那你可以直接将数据从一个channel(译者注:channel中文常译作通道)传输到另外一个channel. transferFro ...

  6. Laravel大型项目系列教程(五)之文章和标签管理

    Laravel大型项目系列教程(五)之文章和标签管理 本节教程将大概完成文章和标签管理. 1.文章管理 首先创建管理后台文章列表视图: $ php artisan generate:view admi ...

  7. html5游戏制作入门系列教程(五)

    我们继续这一系列文章,使用HTML5的canvas组件进行游戏开发.今天,这是相当完整的游戏例子 – 它会回顾经典的旧电脑游戏 – 坦克大战.我会教你使用阵列地图并教你如何检测活动对象(坦克)与环境( ...

  8. 我的数据分析全系列教程,记录着那些大学奋斗的时光

    @Author : By Runsen @Written Date:2020/05/14 作者介绍:Runsen目前大三下学期,专业化学工程与工艺,大学沉迷日语,Python, Java和一系列数据分 ...

  9. Keil(MDK-ARM)系列教程(五)_Configuration(Ⅰ)

    推荐 分享一个大神的人工智能教程.零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到人工智能的队伍中来!http://www.captainbed.net/strongerhuang 我的网站:h ...

最新文章

  1. “国产操作系统最大难题在于解决「生产关系」” | 人物志
  2. Silverlight4 学习视频(四)
  3. anaconda有什么用?pycharm有什么用?anaconda怎么与pycharm一起联合使用?
  4. python os.popen()方法(用于从一个命令打开一个管道)
  5. mysql哪些_初学MySQL哪些需要你知道
  6. java中sql去除游标_java.sql.SQLException:-ORA-01000:已超过最大打开游标
  7. IOS开发基础之OC的Block入门_Day09-Block
  8. 安装VS2008关于解决磁盘已满问题方案.
  9. android framework-下载Android系统源代码
  10. PostgreSQL Logical Replication
  11. 关于vs2015每次打开都要配置opencv问题
  12. WGS84经纬度坐标转化成UTM坐标
  13. 实战PyQt5: 137-QChart图表之散点图
  14. Mac下用命令行打开pdf文件
  15. java rrd 读取_rrd4j的使用详解1–数据保存入rrd文件 | 学步园
  16. 拷机软件 从软件测试中得知自己机器的性能
  17. Zend Guard加密PHP项目图文分解教程,加密兼容PHP7.x
  18. word上次启动失败,安全模式可以帮你解决问题
  19. 5年软件渗透测试工程师的从业经验分享,值得借鉴
  20. 手机 长按删除 html5,移动端长按删除

热门文章

  1. BZOJ 2733 线段树的合并 并查集
  2. shell编程详解(一)
  3. 面向对象程序设计 第六次作业
  4. 信息安全系统设计基础_exp1
  5. io.js 1.0.x发布
  6. [Bug]The maximum array length quota (16384) has been exceeded while reading XML data.
  7. Nvidia DX10 Lighting例子解析
  8. 分享一个HTML5画布实现的超酷文字弹跳球效果
  9. SVN、Apache和AD LDS的集成
  10. ***学习笔记教程五:***技术