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

在 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