Node.js——express中间件(全局中间件、路由中间件、静态资源中间件)

个人简介

👀个人主页: 前端杂货铺

🙋‍♂️学习方向: 主攻前端方向,正逐渐往全干发展

📃个人状态: 研发工程师,现效力于中国工业软件事业

🚀人生格言: 积跬步至千里,积小流成江海

🥇推荐学习:🍍前端面试宝典 🎨100个小功能 🍉Vue2 🍋Vue3 🍓Vue2/3项目实战 🥝Node.js实战 🍒Three.js

🌕个人推广:每篇文章最下方都有加入方式,旨在交流学习&资源分享,快加入进来吧

内容 参考链接
Node.js(一) Node.js------fs(文件系统)模块
Node.js(二) Node.js------path(路径操作)模块
Node.js(三) Node.js------http 模块(一)
Node.js(四) Node.js------http 模块(二)
Node.js(五) Node.js------express项目搭建、请求、响应

文章目录

前言

上篇文章我们学习了如何搭建 Express 项目,并认识了请求和响应的相关知识。

这篇文章我们来认识一下 Express 中的一个重要概念 => 中间件


中间件概念

中间件(Middleware)本质上是一个回调函数,中间件函数可以像路由一样访问请求对象和响应对象。

中间件的作用:使用函数封装公共组件,简化代码。

中间件类型:全局中间件、路由中间件。


全局中间件

全局中间件是应用于整个应用程序的中间件,即所有请求都会经过这些中间件。它们通常用于执行一些全局的任务。

  • 日志记录:记录每个请求的详细信息,如请求方法、URL、状态码、响应时间等。
  • 错误处理:捕获和处理应用程序中发生的错误,确保服务器不会因为未处理的异常而崩溃。
  • 跨域资源共享(CORS):允许或拒绝来自不同源的请求,以支持跨域请求。
  • 静态文件服务:为应用程序提供静态文件(如HTML、CSS、JavaScript、图片等)。
  • 请求体解析:解析请求体中的JSON、URL编码的数据或表单数据。
  • 身份验证:验证请求是否来自已认证的用户,并添加用户信息到请求对象中。
javascript 复制代码
const express = require("express");

const app = express();
const fs = require("fs");
const path = require("path");

// 声明中间件函数
function recordMiddleware(req, res, next) {
  const { url, ip } = req;
  // 将信息保存在文件中
  fs.appendFileSync(
    path.resolve(__dirname, "./access.log"),
    `${url} ${ip}\r\n`
  );

  // 放行
  next();
}

// 使用中间件函数
app.use(recordMiddleware);

app.get("/home", (req, res) => {
  res.send("前台首页");
});

app.get("/admin", (req, res) => {
  res.send("后台首页");
});

app.get("*", (req, res) => {
  res.send("Not Found");
});

app.listen(3000, () => {
  console.log("服务已启动,端口 3000 正在监听中...");
});

路由中间件

路由中间件是应用于特定路由或路由组的中间件,只有匹配到这些路由的请求才会经过这些中间件。它们通常用于执行一些与特定路由相关的任务。

  • 特定路由的日志记录:只记录特定路由的请求信息。
  • 特定路由的身份验证:只对特定路由进行身份验证,例如,只有某些API端点需要身份验证。
  • 数据验证和格式化:在将数据传递给路由处理程序之前,验证和格式化请求数据。
  • 条件性路由处理:根据某些条件决定是否继续处理请求或重定向到其他路由。
javascript 复制代码
const express = require("express");

const app = express();

// 声明路由中间件函数
let checkCodeMiddleware = (req, res, next) => {
  // 当携带的 code 为 666 时才放行,不然提示 "暗号错误"
  if (req.query.code === "666") {
    next();
  } else {
    res.send("暗号错误");
  }
};

// 第二个参数的位置使用路由中间件
app.get("/home", checkCodeMiddleware, (req, res) => {
  res.send("前台首页");
});

app.get("/admin", checkCodeMiddleware, (req, res) => {
  res.send("后台首页");
});

app.get("*", (req, res) => {
  res.send("Not Found");
});

app.listen(3000, () => {
  console.log("服务已启动,端口 3000 正在监听中...");
});

静态资源中间件

通过 app.use(express.static(__dirname) + "/public") 来添加静态资源中间件。

静态资源应放入 public 文件夹中,我们创建如下的目录结构。

注意事项:

  1. index.html 文件为默认打开的资源。
  2. 如果静态资源与路由规则同时匹配,谁先匹配谁就响应。
  3. 路由响应动态资源,静态资源应由中间件响应。
javascript 复制代码
const express = require("express");

const app = express();

app.use(express.static(__dirname + "/public"));

app.get("/home", (req, res) => {
  res.send("前台首页");
});

app.listen(3000, () => {
  console.log("服务已启动,端口 3000 正在监听中...");
});

总结

本篇文章我们学习了中间件的使用,包括 全局中间件、路由中间件和静态资源中间件 ,它们都有各自的使用场景,它们本质上都是一个回调函数,主要用于 请求预处理、响应后处理、错误处理、日志记录、权限控制、性能优化 等。

好啦,本篇文章到这里就要和大家说再见啦,祝你这篇文章阅读愉快,你下篇文章的阅读愉快留着我下篇文章再祝!


参考资料:

  1. Node.js教程(菜鸟教程)
  2. Node.js零基础视频教程(尚硅谷 · 李强)


相关推荐
shykevin6 小时前
DBSyncer开源数据同步中间件
中间件·开源
m0_748232929 小时前
ERROR:This version of pnpm requires at least Node.js vXXX 的解决方案
node.js
爱学习的狮王9 小时前
ubuntu18.04安装nvm管理本机node和npm
前端·npm·node.js·nvm
zhanggongzichu9 小时前
npm常用命令
前端·npm·node.js
我命由我1234510 小时前
NPM 与 Node.js 版本兼容问题:npm warn cli npm does not support Node.js
前端·javascript·前端框架·npm·node.js·html5·js
16年上任的CTO10 小时前
一文大白话讲清楚webpack基本使用——11——chunkIds和runtimeChunk
前端·webpack·node.js·chunksid·runtimechunk
Orange30151110 小时前
【自己动手开发Webpack插件:开启前端构建工具的个性化定制之旅】
前端·javascript·webpack·typescript·node.js
yqcoder11 小时前
NPM 包管理问题汇总
前端·npm·node.js
程序菜鸟营11 小时前
nvm安装详细教程(安装nvm、node、npm、cnpm、yarn及环境变量配置)
前端·npm·node.js