Express全系列教程之(五):Express的中间件

1、中间件

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

 

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

 

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

 

1.应用层中间件

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

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来是路由继续向下匹配,那么就能又获得主页数据了:express

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);

  固然也能够简化写法:json

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();cookie

var router = express.Router()

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

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);

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

 

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中间件类型,在实际项目中,中间件都是必不可少的,所以熟悉使用各类中间件会加快项目的开发效率。

相关文章
相关标签/搜索