当前位置: 首页 > article >正文

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编码的数据或表单数据。
  • 身份验证:验证请求是否来自已认证的用户,并添加用户信息到请求对象中。
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端点需要身份验证。
  • 数据验证和格式化:在将数据传递给路由处理程序之前,验证和格式化请求数据。
  • 条件性路由处理:根据某些条件决定是否继续处理请求或重定向到其他路由。
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. 路由响应动态资源,静态资源应由中间件响应。

在这里插入图片描述

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零基础视频教程(尚硅谷 · 李强)

在这里插入图片描述



http://www.kler.cn/a/515419.html

相关文章:

  • 【Rabbitmq】Rabbitmq高级特性-发送者可靠性
  • 3.CSS的背景
  • HackTheBox靶机:Sightless;NodeJS模板注入漏洞,盲XSS跨站脚本攻击漏洞实战
  • IOS 安全机制拦截 window.open
  • Objective-C语言的数据类型
  • 学习第七十四行
  • 【中国电信-安全大脑产品介绍】
  • 华为支付-(可选)特定场景配置操作
  • 4【编程语言的鄙视链原因解析】
  • JS-Web API -day04
  • “推理”(Inference)在深度学习和机器学习的语境
  • 【数据结构】_顺序表
  • stm8s单片机(二)外部中断实验
  • K8S中Pod控制器之Horizontal Pod Autoscaler(HPA)控制器
  • 【HTML+CSS】使用HTML与后端技术连接数据库
  • 【漏洞复现】|方正畅享全媒体新闻采编系统reportCenter.do/screen.do存在SQL注入
  • Games104——游戏中地形大气和云的渲染
  • Couchbase UI: Dashboard
  • 为什么mysql更改表结构时,varchar超过255会锁表
  • bootloader
  • 3Dgaussian-splatting部署使用流程
  • llama-2-7b权重文件转hf格式及模型使用
  • 初步搭建并使用Scrapy框架
  • 深入探讨:如何在 Debian 系统中实施有效的安全配置
  • 《2024年度网络安全漏洞威胁态势研究报告》
  • Flask之SQL复杂查询