3个中间件 m1.js m2.js m3.js
//执行app中处理过程
function m1(ctx){
// 2种信息request进 respnece出 , ctx是全局的对象
global.console.log('m1',ctx.path)
}
// 导出数据
module.exports = function(){
return async function (ctx,next) {
global.console.log('m1 start')
m1(ctx)
//运行完毕, 交给下一个中间件处理
await next()
global.console.log('m1 end')
}
}
m2.js
m3.js
和m1.js
类似
使用中间件
const m1 = require('./middleware/m1')
const m2 = require('./middleware/m2')
const m3 = require('./middleware/m3')
app.use(m1())
app.use(m2())
app.use(m3())
分析
进入的顺序是m1
,m2
,m3
, 出去的顺序是m3
,m2
,m1
,像是一个层层包裹的洋葱, 一边进入, 一边出去, 无论调用哪一个中间件, 都要经过其他所有的中间件