middleware中间件的概念

时间:2025-01-08 09:07:26

简要来说express就是一个由路由和中间件构成的 web 开发框架。

当express服务收到客户端的请求时,会通过一组函数来处理请求。

这些函数用于解析请求体数据,处理错误,或者负责返回各种情况对应的消息,这种函数就叫中间件。

express中的中间件函数形如:

app.use(function middleware1(req, res, next){
// logic
});

req是请求体,附带着各种请求信息的属性,res附带返回信息的一些方法。

每个中间件应该只处理一种情况,并且,这些函数参数中的req是同一个对象。

因此,前面的中间件如果修改了req,后面的会得到修改后的对象。

当中间件接收到的req已经处理完了,或是没有达到处理条件,就调用next方法跳到下一个中间件处理。

如果既没调用res返回信息,也没调用next跳过,服务就会处于挂起状态。

默认的,如果一个请求跳过了所有中间件也没有得到返回,express会返回500返回码。


一个完整的事例

var express = require('express');
var app = express(); app.use(function(req,res,next){
// 这里可以访问req.body 来查看请求的参数
// 通过调用res.send() 来发送信息 // 没有该中间件要处理的情况 调用next跳到下一个中间件
});

当然,express在这基础上做了一些封装,减少了代码量。

例如要限定中间件所处理的uri,可以这么写

app.use('/requestURI', function(req,res,next){
// 这里当请求的uri跟指定uri不符,自动跳过该中间件
});

除了uri外,还可以根据请求方法来限制

app.use('/requestURI', function(req, res, next){
if('get' !== req.method.toLowercase()) next(); // your logic
});

相当于

app.get('/requestURI', function(req, res, next){
// your logic
});

组合起来

app.get('/requestURI', function(req, res, next){
// your logic
});

express支持get, post, put, delete等动词方法。


中间件对参数的支持。

当我们需要在uri中加入查询参数时,可以这么写

app.use('/requireURI/:qurey', functinor(req, res, next){
console.log(req.params.qures);
});

通过express我们可以快速开发一个web应用。