Hapi.js 中间件原理及实践 - 封装中间件避免重复编写 bug

前言

在使用 Hapi.js 开发 web 应用时,我们常常需要借助中间件来完成一些特定的任务,比如身份认证、日志记录、错误处理等等。本文将介绍 Hapi.js 中间件的原理及实践,重点讲解如何封装中间件来避免重复编写 bug。

Hapi.js 中间件是什么

中间件(Middleware)是 Hapi.js 的一种插件机制,类似于 Express 中的中间件。中间件是一段可插拔的代码,可以在请求被处理前、处理过程中或者处理后对请求进行拦截、修改、增强等操作。在 Hapi.js 中,中间件可以被添加到路由上,也可以被添加到服务器实例上。

Hapi.js 中间件的分类

Hapi.js 中间件可以分为两类:

应用级中间件

应用级中间件是添加到路由上的中间件,只能针对指定的路由生效。应用级中间件可以通过 server.route() 方法来添加,也可以通过路由选项中的 pre 或者 post 字段来添加。

示例代码

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

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

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

在上面的代码中,我们添加了一个应用级中间件,用来记录请求日志。该中间件的主体逻辑是将请求方法、请求路径和当前时间输出到控制台。中间件的添加方式是通过设置路由选项的 pre 字段来实现的。

插件级中间件

插件级中间件是添加到服务器实例上的中间件,可以对所有路由生效。插件级中间件可以通过 server.ext() 方法来添加。

示例代码

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

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

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

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

在上面的代码中,我们添加了一个插件级中间件,用来记录请求日志。该中间件的主体逻辑和应用级中间件是相同的,唯一的区别是添加方式。中间件的添加方式是通过 server.ext() 方法实现的。

中间件的执行顺序

在 Hapi.js 中,每个请求都会经过一系列中间件的处理,我们需要了解这些中间件的执行顺序。

Hapi.js 中间件的执行顺序可分为三个阶段:

  1. 应用级前置中间件(app pre-handler)
  2. 路由级前置中间件(route pre-handler)
  3. 路由处理函数(route handler)
  4. 路由级后置中间件(route post-handler)
  5. 应用级后置中间件(app post-handler)

应用级前置中间件是添加到服务器实例上的中间件,是所有中间件中最先执行的;应用级后置中间件也是添加到服务器实例上的中间件,是所有中间件中最后执行的。路由级中间件分为前置和后置两种,在路由级中间件和路由处理函数之间的执行顺序是由路由选项中 pre 字段和 handler 字段的定义顺序决定的。

封装中间件

当我们需要在多个路由或者多个项目中使用同一个中间件时,我们可以将其封装为一个单独的模块,避免重复编写代码。下面我们以错误处理中间件为例,来介绍如何封装中间件。

示例代码

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

在上面的代码中,我们将一个错误处理中间件封装成了一个可复用的模块。当请求出现错误时,该中间件将输出错误信息到控制台,并返回一个错误信息给客户端。

我们可以将该中间件添加到多个路由中,如下所示:

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

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

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

可以看到,通过封装中间件,我们可以避免重复编写相同的错误处理逻辑,并且更易于维护。

总结

Hapi.js 中间件是一种非常强大的插件机制,可以通过添加中间件来实现各种特定的功能。在编写中间件时,我们需要了解中间件的分类和执行顺序,以及如何封装中间件避免重复编写代码。希望本文能对你了解 Hapi.js 中间件有所帮助。

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


猜你喜欢

  • Node.js 中发生异常时如何进行错误处理

    Node.js 是一门非常流行的服务器端 JavaScript 运行时环境。在开发过程中,错误和异常是难免存在的。因此,在编写代码时,我们需要考虑如何进行异常处理。

    1 年前
  • Mongoose 连接 MongoDB 时出现错误解决方案

    如果你在使用 Mongoose 连接 MongoDB 数据库时遇到了错误,本文将为你提供解决方案。Mongoose 是一个流行的 Node.js ORM 库,它允许你在 Node.js 应用程序中使用...

    1 年前
  • Serverless 架构下如何实现 WebSocket 消息推送?

    什么是 Serverless 架构? Serverless 架构是一种基于云计算的应用开发模式,它的基本思想是将应用中的某些功能模块运行在云端,由云平台提供服务,而应用中的其他模块则在本地部署并运行。

    1 年前
  • 调试 Redux 应用的技巧和工具

    Redux 是一个流行的 JavaScript 应用程序状态管理工具。它使用几个重要的概念,如 store、reducer、action 和 dispatch,来使应用程序状态管理变得更加简单和可控。

    1 年前
  • ECMAScript 2016 中的 Object 扩展:如何进行对象的冻结、密封和可扩展状态控制

    在 JavaScript 中,对象是非常重要的基础概念。因此,ECMAScript 2016 引入了 Object 扩展,包括了对象的冻结、密封和可扩展状态控制。 什么是对象冻结? 对象冻结是一种机制...

    1 年前
  • 初学者 Docker 容器网络配置,不容错过

    什么是 Docker 容器网络? 在 Docker 中,容器网络是一种在主机内创建虚拟网络的方式。每个容器都可以加入一个或多个网络,并在其中运行自己的服务。这种网络可以是私有的,也可以是公共的。

    1 年前
  • ES2021 之可选链操作演示

    在前端开发中,我们经常会遇到需要处理嵌套对象的情况,而在早期的 JavaScript 版本中,处理嵌套对象时需要用到很多繁琐的判断语句来保证代码安全性。这样的做法既低效又容易出错,让开发者在编写代码时...

    1 年前
  • 详解 ES8 中的 rest 操作符

    在 ES6 中,我们已经了解了箭头函数、模板字符串、解构赋值等重要的特性,这些特性已经极大地提高了 JavaScript 的开发效率。而在 ES8 中,新增了 rest 操作符,使其拥有更好的可读性和...

    1 年前
  • vue-cli 3.0 源码解读之 webpack4.0 篇

    Vue-CLI 3.0 是一个用于快速搭建 Vue.js 项目的脚手架工具,它集成了大量的工具,其中包括 Webpack 4.0。在使用 Vue-CLI 3.0 搭建项目时,Webpack 扮演着非常...

    1 年前
  • ES10 如何使用 Optional Catch Binding 解决代码错误

    随着 JavaScript 语言的不断发展,新特性和新语法层出不穷。ES10 也并不例外,除了一些新的 API 和语言特性,Optional Catch Binding 是其一个非常有用的新特性,它能...

    1 年前
  • 如何创造出一个最优的 ESLint 配置文件

    如何创造出一个最优的 ESLint 配置文件 ESLint 是一个强大的 JavaScript 语法检查工具,它可以检测出代码的潜在问题,提供代码质量的保障。随着前端技术发展的不断提升,ESLint ...

    1 年前
  • 使用 Webpack4 打包 SPA 时,如何实现文件版本号控制及缓存优化

    前置知识 在介绍如何使用 Webpack4 实现文件版本号控制和缓存优化之前,需要了解一些前置知识: Cache-Control:HTTP 响应头中的一个字段,用于控制浏览器如何缓存页面和静态资源。

    1 年前
  • Socket.io 在 React Native 中的使用教程

    本文将介绍如何在 React Native 中使用 Socket.io 实现实时通讯。Socket.io 是一个基于 WebSocket 协议的封装库,它可以在客户端和服务器端之间实现双向通讯,且支持...

    1 年前
  • Koa2 中使用 Nodemailer 发送邮件的方法

    在现代的前端开发中,电子邮件服务扮演着非常重要的角色。通过电子邮件,我们可以完成很多事情,比如注册、验证、通知等等。在本文中,我们将介绍如何在 Koa2 中使用 Nodemailer 发送电子邮件。

    1 年前
  • 在 Deno 中如何正确地使用 web workers 进行并行计算?

    在前端开发的过程中,我们常常需要进行大量的计算,而这些计算通常会占用大量的时间,影响了应用的性能。一种解决这个问题的方法是使用并行计算来加速这些计算任务的执行。而在 Deno 中,Web Worker...

    1 年前
  • 如何使用 Enzyme 测试 React 组件的 prop 传递?

    前言 在 React 的开发中,有时需要对组件进行测试以确保组件的正确性和稳定性。而 Enzyme 是一个非常流行的 React 组件测试工具,它提供了一种方便灵活的方式来测试 React 组件。

    1 年前
  • Redis 中的 Lock 优化及互斥锁的使用方法

    Redis 是一种高性能键值对存储服务,用于缓存和消息队列等场景,广泛应用于互联网领域。在实际开发中,我们通常需要使用 Redis 来实现分布式锁,保证系统的并发安全性。

    1 年前
  • Cypress 如何对不同页面进行测试

    Cypress 是一款流行的前端测试工具,可以执行端到端的自动化测试,并提供了一系列的 API,使得测试变得更加简易和可读。在进行测试时,有时需要对不同的页面进行测试,本文将介绍如何在 Cypress...

    1 年前
  • RxJS 的错误处理:重试和重定向

    在我们的前端开发中,请求出现错误是比较常见的情况,假设我们正在使用 RxJS 实现异步操作的话,那么在实际的开发中要如何处理这些错误呢?本文将讨论 RxJS 的错误处理方式,重点介绍重试和重定向,希望...

    1 年前
  • Serverless 框架中的 OpenAPI 规范入门

    随着云计算、微服务和容器化等技术的发展,Serverless 架构正在成为越来越多企业的选择。而在 Serverless 应用的开发中,OpenAPI 规范正成为越来越重要的一环。

    1 年前

相关推荐

    暂无文章