koa2 中间件

koa2的中间件是通过 async await 实现的,中间件执行顺序是“洋葱圈”模型。

中间件之间通过next函数联系,当一个中间件调用 next() 后,会将控制权交给下一个中间件, 直到下一个中间件不再执行 next() 后, 将会沿路折返,将控制权依次交换给前一个中间件。

如图:

koa2 中间件实例

app.js:

const Koa = require('koa');

const app = new Koa();

// logger

app.use(async (ctx, next) => {

console.log('第一层 - 开始')

await next();

const rt = ctx.response.get('X-Response-Time');

console.log(`${ctx.method} ----------- ${ctx.url} ----------- ${rt}`);

console.log('第一层 - 结束')

});

// x-response-time

app.use(async (ctx, next) => {

console.log('第二层 - 开始')

const start = Date.now();

await next();

const ms = Date.now() - start;

ctx.set('X-Response-Time', `${ms}ms`);

console.log('第二层 - 结束')

});

// response

app.use(async ctx => {

console.log('第三层 - 开始')

ctx.body = 'Hello World';

console.log('第三层 - 结束')

});

app.listen(3000);

第一层 - 开始

第二层 - 开始

第三层 - 开始

第三层 - 结束

第二层 - 结束

打印第一次执行的结果: GET -------- /text ------ 4ms

第一层 - 结束

koa2 中间件应用

下面是一个登陆验证的中间件:

loginCheck.js:

module.exports = async (ctx, next) => {

if (ctx.session.username) {

// 登陆成功,需执行 await next(),以继续执行下一步

await next()

return

}

// 登陆失败,禁止继续执行,所以不需要执行 next()

ctx.body = {

code: -1,

msg: '登陆失败'

}

}

在删除操作中使用 loginCheck.js :

router.post('/delete', loginCheck, async (ctx, next) => {

const author = ctx.session.username

const id = ctx.query.id

// handleDelete() 是一个处理删除的方法,返回一个 promise

const result = await handleDelete(id, author)

if (result) {

ctx.body = {

code: 0,

msg: '删除成功'

}

} else {

ctx.body = {

code: -1,

msg: '删除失败'

}

}

})

express 中间件

与 koa2 中间件不同的是,express中间件一个接一个的顺序执行, 通常会将 response 响应写在最后一个中间件中

主要特点:

app.use 用来注册中间件

遇到 http 请求,根据 path 和 method 判断触发哪些中间件

实现 next 机制,即上一个中间件会通过 next 触发下一个中间件

express 中间件实例

const express = require('express')

const app = express()

app.use((req, res, next) => {

console.log('第一层 - 开始')

setTimeout(() => {

next()

}, 0)

console.log('第一层 - 结束')

})

app.use((req, res, next) => {

console.log('第二层 - 开始')

setTimeout(() => {

next()

}, 0)

console.log('第二层 - 结束')

})

app.use('/api', (req, res, next) => {

console.log('第三层 - 开始')

res.json({

code: 0

})

console.log('第三层 - 结束')

})

app.listen(3000, () => {

console.log('server is running on port 3000')

})

执行app.js后,浏览器访问 http://localhost:3000/api , 控制台输出结果:

第一层 - 开始

第一层 - 结束

第二层 - 开始

第二层 - 结束

第三层 - 开始

第三层 - 结束

因为上面各个中间件中的 next() 是异步执行的,所以 打印结果是线行输出的。

如果取消上面next()的异步执行,直接按如下方式:

const express = require('express')

const app = express()

app.use((req, res, next) => {

console.log('第一层 - 开始')

next()

console.log('第一层 - 结束')

})

app.use((req, res, next) => {

console.log('第二层 - 开始')

next()

console.log('第二层 - 结束')

})

app.use('/api', (req, res, next) => {

console.log('第三层 - 开始')

res.json({

code: 0

})

console.log('第三层 - 结束')

})

app.listen(3000, () => {

console.log('server is running on port 3000')

})

执行app.js后,浏览器访问 http://localhost:3000/api , 控制台输出结果:

第一层 - 开始

第二层 - 开始

第三层 - 开始

第三层 - 结束

第二层 - 结束

第一层 - 结束

可见,express 的中间件也可以形成“洋葱圈”模型,但是一般在express中不会这么做,因为 express 的 response 一般在最后一个中间件,所以其它中间件 next() 后的代码影响不到最终结果。

express 中间件应用

下面是一个登陆验证的中间件:

loginCheck.js:

module.exports = (req, res, next) => {

if (req.session.username) {

// 登陆成功,需执行 next(),以继续执行下一步

next()

return

}

// 登陆失败,禁止继续执行,所以不需要执行 next()

ctx.body = {

code: -1,

msg: '登陆失败'

}

}

在删除操作中使用 loginCheck.js :

router.post('/delete', loginCheck, (req, res, next) => {

const author = req.session.username

const id = req.query.id

// handleDelete() 是一个处理删除的方法,返回一个 promise

const result = handleDelete(id, author)

return result.then(val => {

if (val) {

ctx.body = {

code: 0,

msg: '删除成功'

}

} else {

ctx.body = {

code: -1,

msg: '删除失败'

}

}

})

})

koa2 mysql 中间件_Koa2 和 Express 中间件对比相关推荐

  1. node.js学习笔记3 express基本使用、托管静态资源、express中间件

    内容 1. 什么是express 1.1 http模块和express的关系 2. express能做什么 3. express的基本使用 3.1 安装 3.2 创建最基本的web服务器 3.3 监听 ...

  2. koa2 mysql 中间件_Koa2——中间件

    1.什么是koa2中间件? koa对网络请求采用了中间件的形式处理,中间件可以介入请求和相应的处理,是一个轻量级的模块,每个中间负责完成某个特定的功能.中间件的通过next函数联系,执行next()后 ...

  3. koa2 mysql 中间件_Koa2第二篇:中间件

    第一篇介绍了生成器目录设计.xyzcoding:Koa2第一篇:详解生成器​zhuanlan.zhihu.com 接下来学习Koa2的中间件. Koa2本身只能算一个极简的HTTP服务器,自身不内置中 ...

  4. Node.js b站教学视频汇总笔记(完)CommonJS模块规范、 require、npm、Express(中间件)、MongoDB、MySQL

    文章目录 Node.js b站教学视频汇总笔记(完)CommonJS模块规范. require.npm.Express(中间件).MongoDB.MySQL 1. Node介绍 为什么要学习Node. ...

  5. 【随笔】express中间件系统的基本实现

    一直觉得express的中间件系统这种流式处理非常形象,就好像加工流水线一样,每个环节都在针对同一个产品的不同部分完成自己的工作,最后得到一个成品.今天就来实现一个简易的[中间件队列]. 一. API ...

  6. Express中间件工作原理介绍

    Express中间件工作原理介绍 中间件是Express框架学习中最难的部分,同时也是最为核心的技术,我们的学习路线如下 1.什么是中间件 2.Express中间件的本质及工作原理 3.自定义解析po ...

  7. 二、express中间件

    一.中间件引入 实现加入日志模块功能: 1. 我们能想到的方案: 将日志输出代码封装到函数中,然后需要日志输出的地方调用这个函数即可. app.js文件: const express = requir ...

  8. 【nodejs原理源码赏析(1)】Express中间件系统的基本实现

    一直觉得express的中间件系统这种流式处理非常形象,就好像加工流水线一样,每个环节都在针对同一个产品的不同部分完成自己的工作,最后得到一个成品.今天就来实现一个简易的[中间件队列]. 一. API ...

  9. express中间件系统的基本实现

    一直觉得express的中间件系统这种流式处理非常形象,就好像加工流水线一样,每个环节都在针对同一个产品的不同部分完成自己的工作,最后得到一个成品.今天就来实现一个简易的[中间件队列]. 一. API ...

最新文章

  1. Flutter开发使用PlatformView显示iOS原生View(50)
  2. 曾经觉得学习晦涩难懂的我是如何爱上linux的
  3. 设置secureCRT中vim的字体颜色
  4. GIS实战应用案例100篇(十五)-CASS插件应用:如何控制点属性与点名统一
  5. a标签点击事件_html常用标签
  6. java 32位_Java知识点:创建节约内存的JavaBean
  7. Increasing Frequency(CF-1082E)
  8. c语言怎么产生随机字母,菜鸟求助,写一个随机输出26个英文字母的程序
  9. 产品功能优先级,到底该如何确定?
  10. 啊哈C语言 第二章 【代码】【习题答案】
  11. 投票系统程序设计缺陷分析
  12. Linux Oracle卸载步骤
  13. 厦门大学国家奖学金答辩PPT模板
  14. java会导致蓝屏么_电脑经常会蓝屏?可能是这些原因导致的
  15. flv怎么转换成mp4格式
  16. 容斥原理 原理及模板代码
  17. Macbook无法登陆APP Store解决办法
  18. 读书印记 - 《自私的基因》
  19. b站《史上最全unity3D教程》笔记1-03
  20. 上海宝付谈谈故宫瘫痪,程序员怎么办

热门文章

  1. 关于增强学习你应该了解的五件事儿
  2. 一行 Python 代码能实现这么多丧心病狂的功能?(代码可复制)
  3. 纪·阿晶的首次AWS之行!
  4. 2019 年度程序员吸金榜:你排第几?
  5. 使用云原生buildpacks将你的代码转换成Docker Image | 技术干货
  6. Cloud一分钟 | 华云数据中标上药控股私有云千万级项目; 总投资90亿元的中国移动厦门数据中心,一期电源工程项目候选人公示...
  7. http中的请求头各部分都是什么意思_硬核!30 张图解 HTTP 常见的面试题
  8. 分布式任务调度平台一站式讲解
  9. Docker JFrog Artifactory 7.27.10 maven私服(搭建篇)
  10. SpringBoot集成Myabtis