Hapi.js:构建稳健 Node.js 应用的解决方案

面试官:小伙子,你的代码为什么这么丝滑?

引言

Node.js 可以说是当今 Web 开发领域最具热度的技术之一,特别是在构建实时应用、RESTful API 或者微服务等方面展现出了巨大的优势。然而,摸着初学者的良心与责任,我们必须承认,Node.js 本身是一个非常基础的平台。

Node.js 的核心特性是单线程非阻塞 I/O,同时也是因为这个特性,它能够在处理高并发请求时表现优异。但是问题在于,为了构建真正完整的应用,我们需要花费更多的时间和精力来处理诸如路由控制、请求响应、身份验证、错误处理等方面的功能。

这才有了一个优秀的中间件库——Hapi.js。在本篇文章中,我们将探讨如何使用 Hapi.js 构建一个稳健的 Node.js 应用。

Hapi.js 简础

Hapi.js 是一个可以快速构建应用的框架,它提供了丰富的插件及工具集来帮助我们管理路由、开发视图、处理输入等。Hapi.js 所提供的工具,可以大大增强我们在开发过程中使用 Node.js 的效率。

安装

Hapi.js 可以通过 NPM 来进行安装,我们可以使用以下命令进行安装:

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

创建 Hapi.js 服务

创建一个 Hapi.js 服务,只需要通过 Hapi 的构造器函数 Server 即可实现:

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

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

在服务启动之后,我们可以通过浏览器访问 http://localhost:3000 来查看服务是否已经正常运行。

路由

在 Hapi.js 中,我们可以使用路由来控制处理请求的方式,从而实现一系列的功能。我们可以通过以下代码简单创建一个路由:

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

我们通过 route 方法来添加路由,它包括三个属性:

  • method:表示 HTTP 请求的方法,比如 GET、POST、PUT、DELETE 等;
  • path:表示 URL 路径;
  • handler:表示路由处理函数,在方法与路径匹配时触发。

Response

响应是客户端访问我们服务器的结果。在 Hapi.js 中,我们可以对响应进行完整的控制,其中包括状态码、HTTP 头、内容类型以及响应体的内容等内容。

在 Hapi.js 中,我们可以使用 h 来控制响应体,例如:

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

Hapi.js 进阶

到这里,我们已经了解了如何使用 Hapi.js 构建一个最基本的服务。接下来,我们将一步步深入了解 Hapi.js,探索一些进阶的用法,例如身份验证、插件以及处理错误等。

身份验证

对于需要身份验证的应用程序,Hapi.js 提供了非常方便的身份验证机制。Hapi.js 身份验证插件包括了本地身份验证、OAuth、JSON Web Token 等多个身份验证机制。下面,我们介绍一下如何使用 Hapi.js 进行本地身份认证。

使用同步函数进行本地身份认证

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

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

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

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

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

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

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

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

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

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

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

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

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

-------

我们通过 hapi-auth-basic 模块进行基础身份验证。在上面的实现中,当你请求应用程序的根路径 / 时,需要验证用户的应用程序发出的凭据。在此处,我们通过对 users 对象进行比较,使用了同步的 bcrypt.compare() 函数,以 usernamepassword 来对用户进行验证。只有当 isValid = true 时,才会将请求发送至路由处理程序。

插件

Hapi.js 插件在应用程序模块化方面非常有用。插件通常用于处理跨应用程序多个路由的功能。使用插件跟添加任何其他路由一样简单。我们可以使用 server.register() 将插件添加到 Hapi.js 服务中。

下面,我们创建一个简单的插件,将在浏览器中发送响应前等待一秒钟:

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

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

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

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

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

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

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

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

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

-------

通过 server.ext() 方法,我们可以在请求处理期间运行通用代码。在上面的示例中,我们使用 type: 'onPreResponse' 将代码添加到每个响应之前的事件中,以等待 1 秒钟。

处理错误

最后,我们来处理一下错误。Hapi.js 允许我们在全局范围内定义所有失败的路由。如果在应用程序中未找到与请求匹配的路由时,Boom.notFound() 将返回一个 404 状态码。

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

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

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

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

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

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

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

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

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

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

-------

结论

在本文当中,我们学习了如何使用 Hapi.js 构建一个完整的 Node.js 应用。我们已经熟悉了创建路由、处理响应、身份验证、使用插件和处理错误等方面的操作。

总之,Hapi.js 是 Node.js 应用程序开发的一个很棒的解决方案。它提供了一套优秀的工具来帮助我们轻松地处理一些开发细节,从而减轻了我们的负担,能够让我们集中精力于应用程序本身的业务逻辑。

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


猜你喜欢

  • React 项目中使用 React Native 的技巧

    React Native 是 Facebook 推出的一款跨平台移动应用开发框架,通过使用 JavaScript 和 React 技术栈,它可以快速开发出高效、原生级别的移动应用程序。

    25 天前
  • GraphQL 中实现分布式事务的方法

    现代应用程序的复杂性越来越高,这也引发了越来越多的微服务和分布式系统的使用。当需要多个服务协作时,分布式事务非常重要。在这篇文章中,我们将讨论如何在 GraphQL 中实现分布式事务。

    25 天前
  • 在 React 项目里使用 ES10 的新特性 optional chaining

    随着 JavaScript 的版本更新,我们可以用更简洁的代码来完成我们的任务,ES10 带来了一系列新特性,其中 optional chaining 是一个很有用的特性,它可以使代码更加简洁和易于维...

    25 天前
  • 如何避免响应式设计中出现的多余 CSS 代码

    在实施响应式设计时,一个常见的问题是产生大量的多余 CSS 代码。这会降低页面性能并增加维护的难度。在本文中,我们将讨论如何避免这些问题,使您的网站更加高效和易于管理。

    25 天前
  • 在 Cypress 中如何解决获取元素失败的问题?

    问题描述 在使用 Cypress 进行前端自动化测试时,经常会出现获取元素失败的问题。例如,在进行单元测试或端对端测试时,我们需要在页面上找到特定的 DOM 元素,以便对其进行操作或者断言其属性。

    25 天前
  • Mocha 测试套件中的测试数据生成实现方法

    在前端开发中,测试数据的生成对于测试套件的运行非常重要。Mocha 是一种灵活且易于使用的 JavaScript 测试框架,它可以帮助我们轻松地测试应用程序的各个部分,包括生成测试数据。

    25 天前
  • 记录一点关于使用 Inert 的坑 Hapi.js

    在编写 Hapi.js 应用程序时,前端开发人员通常需要通过 Inert 插件来提供静态文件访问功能。 Inert 可以让开发人员轻松地供应静态文件,例如图像、CSS 文件和 JavaScript 文...

    25 天前
  • 在使用 CSS Reset 时应该避免的一些问题

    CSS Reset 是一种常见的前端技术,旨在在不同的浏览器中消除样式差异,使得页面可以在不同的浏览器中保持一致的样式。然而,使用 CSS Reset 时需要注意一些问题,否则可能会造成一些不必要的麻...

    25 天前
  • 在 Deno 中构建即时应用程序

    介绍 Deno 是一种新兴的 JavaScript 和 TypeScript 运行时环境,由 Node.js 的创建者 Ryan Dahl 开发。Deno 是用 Rust 编程语言编写的,是 Type...

    25 天前
  • 在 Koa2 中使用 Vue.js 编写前端应用

    Koa2 是一个轻量级的 Node.js 框架,而 Vue.js 是一个流行的 JavaScript 框架,用于构建用户界面和单页应用程序。在本文中,我们将介绍如何在 Koa2 中使用 Vue.js ...

    25 天前
  • ES11 全新的 Promise APIs: 中断错误投递

    引言 在前端开发中,处理异步代码是无法避免的过程,Promise 是一个常见的异步处理方式。但是在使用 Promise 的过程中,有时会遇到错误处理的问题。在 ES11 中,有全新的 Promise ...

    25 天前
  • jQuery的无障碍性使用技巧

    引言 随着互联网的普及,无障碍性已经成为一个越来越重要的话题。不同的人群有不同的需求和能力,访问互联网的门槛也应该越来越低。本文将介绍jQuery如何支持无障碍性,并提供一些使用技巧。

    25 天前
  • Docker Compose:从零开始构建一个 Node.js Web 应用程序

    Docker Compose 是 Docker 生态系统中的一部分,它可以用于定义和运行多个 Docker 容器组成的应用程序。在本文中,我们将介绍如何使用 Docker Compose 构建一个 N...

    25 天前
  • 如何在 Lambda 函数中使用第三方库

    AWS Lambda 是一个云服务平台,使得开发人员能够在云上运行代码而无需维护服务器。本文将介绍如何在 AWS Lambda 函数中使用第三方库,以便在您的应用程序中可以使用更多的功能。

    25 天前
  • 如何使用 Bootstrap 处理响应式设计中的按钮问题

    Bootstrap 是一个流行的前端框架,它不仅提供了一套强大的样式库,而且还包括了一些优秀的响应式设计组件,如响应式按钮。但是,如果你不知道如何使用 Bootstrap 处理响应式设计中的按钮问题,...

    25 天前
  • TypeScript 中的泛型约束

    在 TypeScript 中,泛型是非常重要的一种类型定义方式,它可以让我们定义更灵活的类型,并且能够提供一定的类型检查能力。但是在使用泛型的时候,我们有时候需要对泛型进行一些约束,以确保泛型的类型满...

    25 天前
  • Kubernetes 指南之初学者指南

    什么是 Kubernetes? Kubernetes 是一个可扩展的开源平台,用于管理容器化工作负载和服务,提供一个易于使用、自动化的方式来部署、扩展和管理应用程序。

    25 天前
  • 利用 Enzyme 实现 React 测试

    React 是当下非常热门的前端框架,很多网站都采用了 React 技术来实现页面交互。然而,在开发过程中,如何保证代码质量,确保程序健壮性和可维护性,是必须要考虑的问题。

    25 天前
  • Socket.IO 如何处理客户端发送速度过快的问题

    在 Web 开发中,实时通信是非常重要的部分。在现代 Web 应用程序中,Socket.IO 成为了一个非常受欢迎的实时通信技术,它能够支持双向通信,可以让客户端和服务器之间进行实时通信。

    25 天前
  • Tailwind index.css 文件大小过大解决方法

    Tailwind 是一个广受欢迎的 CSS 框架,它通过提供一系列实用的类名,可以帮助我们快速地构建响应式和可复用的 UI 组件。然而,随着我们的应用程序变得越来越复杂,Tailwind 的 inde...

    25 天前

相关推荐

    暂无文章