一、中间件引入

实现加入日志模块功能:

1. 我们能想到的方案:

将日志输出代码封装到函数中,然后需要日志输出的地方调用这个函数即可。

app.js文件:

const express = require('express')const app = express()const myLogger = (req) => {console.log(req.method, req.url, Date.now())}app.get('/', (req, res) => {myLogger(req)res.send('get /')
})app.get('/about', (req, res) => {myLogger(req)res.send('get /about')
})app.get('/login', (req, res) => {myLogger(req)res.send('get /login')
})// app.get('/', (req, res) => {//     console.log(req.method, req.url, Date.now())
//     res.send('get /')
// })// app.get('/about', (req, res) => {//     console.log(req.method, req.url, Date.now())
//     res.send('get /about')
// })// app.get('/login', (req, res) => {//     console.log(req.method, req.url, Date.now())
//     res.send('get /login')
// })app.listen(3000, () => {console.log('Server running at http://localhost:3000/')
})

2. 使用中间件

二、中间件的概念


在我理解Express 中间件和AOP面向切面编程就是一个意思,就是都需要经过经过的一些步骤,不去修改自己的代码,以此来扩展或者处理一些功能

什么是AOP?中文意思是面向切面编程,听起来感觉很模糊。先举个生产的例子。


最后在流水线中的空隙插上两个工人去处理,形成采摘-分类-清洗-包装
-贴标签
的新流程,而且工人可以随时撤回。

AOP(Aspect Oriented Programming)面向切面编程:

  • 将日志记录,性能统计,安全控制,事务处理,异常处理等代码从业务逻辑代码中划分出来,通过对这些行为的分离,我们希望可以将它们独立到非指导业务逻辑的方法中,进而改变这些行为的时候不影响业务逻辑的代码
  • 利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率和可维护性

    总结:就是在现有代码程序中,在程序生命周期或者横向流程中加入/减去一个或多个功能,不影响原有功能。

三、Express中的中间件

在Express中,中间件就是一个可以访问请求对象、响应对象和调用next方法的一个函数。

在中间件函数中可以执行以下任何任务:

  • 执行任何代码
  • 修改request 或者response响应对象
  • 结束请求响应周期
  • 调用下一个中间件





注意:如果当前的中间件功能没有结束请求-响应周期,则必须调用next()将控制权传递给下一个中间件功能。否则,该请求将被挂起

四、Express中的中间件分类

在Express中应用程序可以使用以下类型的中间件:

  • 应用程序级别中间件








此示例显示了一个中间件子堆栈,该子堆栈处理对/user/:id路径的GET请求。

  1. next() 不带参数
    表示继续跳转执行下一个middle或者route函数。
  2. next(‘route’)
    表示丢弃当前route的剩余callback函数,注意只在由app.METHOD()/route.METHOD()中定义的middleware函数中生效。
  3. next(! ‘route’)
    对于任何非’route’参数(不管是一个简单数字或者还是一个字符串)都被认为是一个err,跳转到错误处理函数。

中间件也可以在数组中声明为可重用。此示例显示了一个带有中间件子堆栈的数组,该子堆栈处理对/user/:d路径的GET请求

  • 路由级别中间件
    路由器级中间件与应用程序级中间件的工作方式相同,只不过它绑定到实例express.Router()
var router=express.Router()

使用router.use()和router.METHOD()函数加载路由器级中间件.
以下示例代码通过使用路由器级中间件来复制上面显示的用于应用程序级中间件的中间件系统:

  • 错误处理中间件
    以与其他中间件函数相同的方式定义错误处理中间件函数,除了使用四个参数而不是三个参数(特别是使用签名(err,req,res,next))之外:

    错误处理中间件始终带有四个参数。你必须提供四个参数以将其标识为错误处理中间件函数。即使不需要使用该next对象,也必须指定它以维护签名。否则,该next 对象将被解释为常规中间件,并且将无法处理错误。

如果将任何内容传递给该next()函数(字符串除外’route’),Express都会将当前请求视为错误,并且将跳过所有剩余的非错误处理路由和中间件函数。

中间件处理404:

  • 内置中间件
    Express 具有以下内置中间件函数:

  • 第三方中间件
    早期的Express内置了很多中间件.后来Express在4.x之后移除了这些内置中间件,官方把这些功能性中间件以包的形式单独提供出来.这样做的目的是
    为了保持Express本身极简灵活的特性,开发人员可以根据自己的需要去灵
    活的使用.
    有关Express常用的第三方中间件功能的部分列表,请参阅:
    https://www.expressjs.com.cn/resources/middleware.html

    第三方中间件morgan的使用:

morgan用来输出日志信息

  1. npm i morgan
var morgan = require('morgan')
// app.use(morgan('tiny'))
app.use(morgan(':method :url :status :res[content-length] - :response-time ms'))

二、express中间件相关推荐

  1. express中间件和路由教程

    一.路由 1.通常HTTP URL的格式是这样的:http://host[:port][path] http表示协议. host表示主机. port为端口,可选字段,不提供时默认为80. path指定 ...

  2. Node.js—Express、Express 路由 、Express 中间件、使用 Express 写接口

    目标: 能够使用 express.static() 快速托管静态资源 能够使用 express 路由精简项目结构 能够使用常见的 express 中间件 能够使用 express 创建API接口 能够 ...

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

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

  4. koa2 mysql 中间件_Koa2 和 Express 中间件对比

    koa2 中间件 koa2的中间件是通过 async await 实现的,中间件执行顺序是"洋葱圈"模型. 中间件之间通过next函数联系,当一个中间件调用 next() 后,会将 ...

  5. Express 中间件 body-parser 原理分析

    原文出自:https://www.pandashen.com 前言 Express 是基于 NodeJS 平台的 Web 框架,应用广泛,在 Express 社区中有着大量的开发者通过 Express ...

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

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

  7. Node 学习 | Day03 express (初识Express、Express 路由、Express 中间件、使用 Express 写接口)

    Express 初识Express 1.1 Express 简介 1.1.1 什么是 express 1.1.2 进一步理解 Express 1.1.3 Express可以做什么 1.2 Expres ...

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

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

  9. Express 中间件及路由

    通过示例介绍中间件 打印请求日志(输出每个请求的 请求方法 + 请求路径 + 请求时间) app.get('/', (req, res) => {res.send('get /') })app. ...

最新文章

  1. zip的用法python_Python学习之zip函数的用法
  2. oracle之TNS:无监听程序解决办法
  3. 【Redis】11.Redis事务、事务锁
  4. FFmpeg 硬件加速方案概览 (上)
  5. 人工智能选go还是python_深圳人工智能学Python还是go,真实经历分享
  6. aop注解配置切点 spring_Spring通过自定义注解灵活配置AOP切点
  7. Linux中对进程的管理
  8. 架构师这5条禁忌,你犯了么?
  9. 深度学习《CNN架构》
  10. mybatis源码学习篇之——执行流程分析
  11. 运维部门工作总结_运维部工作总结
  12. JS性能优化 之 FOR循环
  13. python基于Flask构建Web服务,解决Flask数据请求中的跨域问题
  14. Qt学习之路_008-最全的Qt学习总结(前期)
  15. 广东省潮州市谷歌卫星地图下载
  16. 计算机图形学(九)-纹理的应用,环境贴图、凹凸贴图、法线贴图、位移贴图
  17. a标签下载静态文件 失败-未发现文件
  18. windows更新错误0x8024401c
  19. 常用线性稳压器技术分析
  20. Skype for Business Server 2015-13-IISARR-2-发布-3-OWAS

热门文章

  1. Flask项目--注册
  2. Linux执行命令提示Password,linux expect远程自动登录以及执行命令
  3. python | 查看pip支持的文件名和版本
  4. Python面向切面编程是什么
  5. c语言结构体中整形数组初始化,c – 将{0,0}在结构体中初始化数组?
  6. android竖直和横向,如何在android中为纵向和横向模式定义不同的控件
  7. centos清除dns cache.
  8. !DOCTYPE 标签是什么
  9. Hibernate学习笔记③
  10. 在线生成大全(这里真的什么都有)