中间件在 Express.js 应用程序中的实践应用

AI 编程助手,豆包旗下的编程助手,提供智能补全、智能预测、智能问答等能力,节省开发时间,释放脑海中的创造力,支持 VSCode,点击体验 AI

在 Express.js 中,中间件(middleware)是处理请求的函数。它们可以访问请求对象(request object)(req)和响应对象(response object)(res),并且可以执行以下任务:

  • 执行任何代码。
  • 结束请求。
  • 调用下一个中间件函数。
  • 如果没有结束请求,则必须调用 next(),以便将控制权传递给下一个中间件。

通过使用中间件,我们可以轻松地添加新功能、优化应用程序并提高安全性。让我们来看看如何在 Express.js 应用程序中应用中间件。

添加中间件

在 Express 应用程序中添加中间件非常简单。我们定义一个函数并将其作为参数传递给 app.use() 方法。例如,以下代码添加了一个名为 logger 的基本中间件:

----- ------- - -------------------
----- --- - ----------

-- ---------
-------- ----------- ---- ----- -
  -------------------------- -------------
  -------
-

-- -----------
----------------

-- --
------------ ----- ---- -- -
  ---------------- ---------
---

---------------- -- -- -
  ------------------- ------- -- ---- -------
---

在上面的代码中,我们定义了一个函数 logger,并在 app.use() 中使用了它。该函数将请求的方法和 URL 输出到控制台,并调用 next() 以将控制权传递给下一个中间件。

在这个例子中,我们仅仅输出了请求的方法和 URL。但是,中间件不仅仅可以用来记录请求。我们可以使用它来执行任何操作,例如验证请求中的数据、验证用户是否已登录等。

模板引擎中间件

Express.js 附带了许多流行的模板引擎中间件,例如 EJS、Pug 和 Handlebars。我们可以使用这些中间件将动态内容渲染为 HTML。下面是一个使用 EJS 模板引擎的例子:

----- ------- - -------------------
----- --- - ----------
----- --- - ---------------

------------- -------- -------

------------ ----- ---- -- -
  ------------------- - ----- ------- ---
---

---------------- -- -- -
  ------------------- ------- -- ---- -------
---

在上面的代码中,我们使用了 EJS 模板引擎中间件。我们可以使用 app.set() 方法来设置模板引擎。这里我们将模板引擎设置为 EJS。

我们还定义了一个路由,并使用 res.render() 方法来渲染名为 index 的 EJS 模板,将数据对象 {name: 'World'} 传递给模板。通过这种方式,我们可以将动态内容渲染为 HTML。

静态文件中间件

Express.js 中的 static 中间件使得静态文件的服务非常容易。我们可以使用它为应用程序提供静态资源,例如图像、CSS 和 JavaScript 文件。让我们看一个例子:

----- ------- - -------------------
----- --- - ----------
----- ---- - ----------------

------------------------------------------- ------------

------------ ----- ---- -- -
  ---------------- ---------
---

---------------- -- -- -
  ------------------- ------- -- ---- -------
---

在上面的代码中,我们使用了 express.static() 中间件,并将 public 文件夹作为静态资源的位置。这样我们就可以访问位于 public 文件夹中的任何静态资源。

错误处理中间件

Express.js 中的错误处理中间件使得捕获和处理错误变得非常容易。当我们的应用程序遇到错误时,它会调用错误处理中间件,而不是触发全局错误事件。以下是一个基本的错误处理中间件示例:

----- ------- - -------------------
----- --- - ----------

------------ ----- ---- -- -
  ----- --- ----------------
---

-- -------
------------- ---- ---- ----- -- -
  -------------------------
  ------------------------------- ---------
---

---------------- -- -- -
  ------------------- ------- -- ---- -------
---

在上面的代码中,我们通过抛出一个新的异常来模拟错误。当发生错误时,控制权会传递到错误处理中间件。这个中间件输出错误堆栈跟踪到控制台,并发送一个简单的错误消息回客户端。

通过使用错误处理中间件,我们可以为我们的应用程序定义自定义错误行为,例如将错误信息发送到管理员或记录到数据库。

结论

中间件是 Expressjs 的核心特性之一,它为我们提供了一种简单而有效的方法来处理请求并添加新的、有用的功能。使用中间件,我们可以通过添加自定义中间件为应用程序增加额外功能、简化代码和错误处理,并提高应用程序的安全性。通过掌握中间件的基本知识和技能,您将能够更好地了解和设计 Express.js 应用程序。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6715ce79ad1e889fe219011b


猜你喜欢

  • 解决 Material Design 样式覆盖其他样式的问题

    Material Design 是 Google 推出的一种设计语言,被广泛应用于 Web 和移动应用的设计中。然而,使用 Material Design 样式时可能会出现样式覆盖的问题,这可能会导致...

    19 天前
  • Promise 的异常捕获及处理方法

    在前端开发中,Promise 是一种非常常见和重要的异步编程方式。然而,在 Promise 中,如果出现异常错误并不会被自动捕获,因此需要我们手动捕获并进行处理。本文将详细介绍 Promise 异常捕...

    19 天前
  • JVM 调优:提高 Java 应用程序的性能

    Java 虚拟机(Java Virtual Machine,JVM)是 Java 语言的核心,它是一种可以解释 Java 字节码并执行 Java 应用程序的虚拟计算机。

    19 天前
  • 如何在 LESS 中处理字体加粗的问题

    如何在 LESS 中处理字体加粗的问题 在前端开发中,经常要用到字体加粗的效果。在 CSS 中,可以使用 font-weight 属性来设置字体粗细。但是在使用 LESS 的时候,可能会遇到一些处理字...

    19 天前
  • PWA 默认主题颜色的更改指南

    在当前的 Web 技术中,渐进式网络应用程序(PWA)正在快速流行。随着越来越多的企业和开发人员使用 PWA,更多的需求,比如更改主题颜色,也随之出现。本文将介绍如何更改 PWA 默认主题颜色,并提供...

    19 天前
  • Node.js 中使用 Fastify 构建 HTTP API 实例

    介绍 Fastify 是一个快速、低开销、且其提供了生产级别的功能的 Web 框架。它专门设计用于构建非常快速的异步 JavaScript 服务。本文将介绍如何使用 Fastify 在 Node.js...

    19 天前
  • GraphQL 中优化查询速度的技巧

    GraphQL 是一种 API 查询语言,它允许前端开发人员对后台数据进行灵活的查询和获取,而无需传统 REST API 中的多个请求和响应。然而,在大型应用程序中,GraphQL 查询可能会变得复杂...

    19 天前
  • Sequelize 中的数据分区处理

    在大型应用程序中,处理数百万或甚至数十亿条数据是非常常见的。然而,处理这么多数据可能会导致一些困惑,因此我们需要一些方法将数据分发到一个或多个地方来更好地处理它。在 Sequelize 中,就有相应的...

    19 天前
  • Deno 引入第三方库遇到问题的解决方法

    前言 Deno 是由 Ryan Dahl 创造,基于 V8 引擎和 Rust 编写的一款安全的 JavaScript 和 TypeScript 运行时环境。它提供了用于编写可靠和可维护的服务端应用程序...

    19 天前
  • CSS Grid 实现多栏布局的底层原理解析

    什么是 CSS Grid? CSS Grid 是 CSS 中一种强大的布局方式,能够帮助我们轻松创建具有多个栏的复杂布局。它提供了一种可用于将页面分为网格和区域的方式,并允许我们对这些区域进行各种排列...

    19 天前
  • Mongoose 中的联合查询详解

    在 Node.js 的开发中,Mongoose 是一种非常流行的用于操作 MongoDB 数据库的中间件。Mongoose 提供了许多功能强大的查询 API,其中之一就是联合查询。

    19 天前
  • Material Design 如何实现自定义主题

    作为一种现代化的设计风格,Material Design 受到了众多设计师和开发人员的青睐。Material Design 风格的应用程序通常具有优雅的外观、流畅的用户体验,并且能够很好地适应各种设备...

    19 天前
  • 在 Node.js 中使用 WebSocket 实现实时通信

    WebSocket 是一种用于实现实时通信的网络协议,它可以在客户端和服务器之间建立一个持久性的双向连接,实现双向实时数据传输。在前端开发中,我们通常使用 WebSocket 来实现实时聊天、实时数据...

    19 天前
  • Kubernetes 使用 Tiller 部署 Helm

    前言 Helm 是 Kubernetes 上最流行的程序包管理器,使用它可以轻松地部署和管理程序包。Helm 通过 chart 来管理程序包,这是一个预定义的目录结构,其中包含了部署一个应用程序所需的...

    19 天前
  • 你真的了解 ES6 的 Promise 使用吗?

    ES6 中引入的 Promise 可以帮我们优化异步编程,提供了一种更加优雅、简洁的方式来处理异步操作。但是,很多前端工程师在使用 Promise 时可能并不是很清楚它的原理和使用方法,导致代码写得很...

    19 天前
  • 如何使用 Jest 测试 Angular 应用程序

    在开发 Angular 应用程序的过程中,测试是非常重要的一环,因为它可以帮助我们确保应用程序的稳定性和可靠性。Jest 是一个流行的 JavaScript 测试框架,可以用于编写和运行测试用例。

    19 天前
  • 如何在 Web Components 中实现自适应布局

    Web Components 是 HTML5 标准的一部分,它是一种可以重复使用的组件模型,使得开发者能够轻松自定义 HTML 标签、开发模块化组件和实现各种 UI、应用和工具功能。

    19 天前
  • 如何为听力有损的用户打造一个无障碍网站?

    在网站开发过程中,我们通常会考虑用户体验,尽可能地提供最好的页面视觉效果和交互体验,但对于有身体障碍的用户,也需要我们更多地关注和支持,例如听力障碍的用户。 在本文中,我们将讨论如何为他们打造一个无障...

    19 天前
  • 在 LESS 中实现多主题切换的技巧

    在前端开发中,我们经常会涉及到多主题切换的需求。例如,用户可以在页面上选择白天模式或者夜间模式。在这篇文章中,我们将介绍如何使用 LESS 实现多主题切换的技巧。 LESS 的 @import 指令 ...

    19 天前
  • 使用 PWA 重构现有 Web 应用程序的最佳实践

    什么是 PWA PWA (Progressive Web Apps) 是一种新兴的 Web 应用开发方式,它结合了 Web 应用和原生应用的优点,可以让 Web 应用在用户体验方面更加接近原生应用,同...

    19 天前

相关推荐

    暂无文章