Express框架——中间件

1. 中间件

1.1 什么是中间件

中间件就是一堆方法, 可以接受客户端发来的请求、可以对请求做出响应,也可以将请求继续交给下一个中间件继续处理。

在这里插入图片描述

  • 中间件主要有两部分构成, 中间件方法以及请求处理函数
  • 中间件方法由Express提供,负责拦截请求,请求处理函数由开发人员提供,负责处理请求。
 app.get('请求路径', '处理函数')   // 接收并处理get请求
 app.post('请求路径', '处理函数')  // 接收并处理post请求
  • 可以针对同一个请求设置多个中间件
  • 默认情况下,请求从上到下依次匹配中间件,一旦匹配成功,终止匹配
  • 可以调用next方法将请求的控制权交给下一个中间件,直到遇到结束请求的中间件
app.get('/request', (req, res, next) => {
  req.name = '张三'
  next()
})

app.get('/request', (req, res) => {
  req.name = '张三'
  res.send(req.name)
})

1.2 app.use 中间件用法

  • app.use匹配所有的请求方式, 可以直接传入请求处理函数, 代表接受所有的请求
  • app.use第一个参数也可以传入请求地址, 代表不论什么请求方式, 只要是这个请求地址就接受这个请求
// 接受所有请求的中间件
app.use((req, res, next) => {
  console.log('请求走了app.use中间件')
  next()
})

// 当客户端访问/request请求的时候走当前中间件
app.get('/request', (req, res, next) => {
  console.log('请求走了/request中间件')
})

app.get('/list', (req, res) => {
  res.send('/list')
})

1.3 中间件应用

  1. 路由保护, 客户端在访问需要登录的页面时, 可以先使用中间件判断用户登录状态, 用户如果未登录, 直接响应, 禁止用户进入需要登录的页面
const express = require('express')

const app = express()

app.use('/admin', (req, res, next) => {
  // 用户没有登录
  let isLogin = true;
  // 如果用户登录
  if (isLogin) {
    // 让请求继续向下执行
    next()
  } else {
    // 如果用户没有登录, 直接对客户端做出响应
    res.send('您还有没有登录, 不能访问/admin这个页面')
  }
})

app.get('/admin', (req, res) => {
  res.send('您已经登录, 可以访问当前页面')
})

app.listen(3000, () => console.log('Server is running...'))

  1. 网站维护公告, 在所有路由的最上面定义接受所有请求的中间件, 直接为客户做出响应, 网站正在维护中
const express = require('express')

const app = express()

// 网站公告
app.use((req, res, next) => {
  res.send('当前网站正在维护...')
})

app.use('/admin', (req, res, next) => {
  // 用户没有登录
  let isLogin = true;
  // 如果用户登录
  if (isLogin) {
    // 让请求继续向下执行
    next()
  } else {
    // 如果用户没有登录, 直接对客户端做出响应
    res.send('您还有没有登录, 不能访问/admin这个页面')
  }
})

app.get('/admin', (req, res) => {
  res.send('您已经登录, 可以访问当前页面')
})

app.listen(3000, () => console.log('Server is running...'))

  1. 自定义404页面
app.use((req, res, next) => {
  // 为客户端响应404状态码以及提示信息
  res.status(404).send('当前访问的页面不存在')
})

1.4 错误处理中间件

  • 在程序执行过程中, 不可避免的会出现一些无法预料的错误, 比如文件读取失败, 数据库连接失败
app.use((err, req, res, next) => {
	res.status(500).send('服务器端发生未知错误')
})
  • 当程序出现错误时, 调用next()方法, 并且将错误信息通过参数的形式传递给next()方法, 即可触发错误处理中间件
app.get('/index', (req, res, next) => {
  fs.readFile('./demo.txt', 'utf8', (err, data) => {
    if (err != null) {
      next(err)
    } else {
      res.send(data)
    }
  })
})

1.5 捕获错误

  • 在nodejs中, 异步API的错误信息都是通过回调函数获取的, 支持Promise对象的异步API发生错误通过catch方法捕获
  • 异步函数执行如果发生错误要如何捕获错误呢
  • try catch 可以捕获异步函数以及其他同步代码在执行过程中发生的错误, 但是不能用于其他类型的API发生的错误
const express = require('express')
const fs = require('fs')
const promisify = require('util').promisify
const readFile = promisify(fs.readFile)

const app = express()

app.get('/index', async (req, res, next) => {
  try {
    await readFile('./aa.js')
  } catch (err) {
    next(err)
  }  
})

// 错误处理中间件
app.use((err, req, res, next) => {
  res.status(500).send(err.message)
})

app.listen(3000, () => console.log('Server is running...'))

猜你喜欢

转载自blog.csdn.net/weixin_47085255/article/details/107487576