使用 Hapi.js 实现前后端分离 + 路由级权限控制

随着互联网技术的不断发展,越来越多的公司采用前后端分离的架构模式来开发 Web 应用程序。前后端分离能够大大提高开发效率,并且具有良好的可扩展性和可维护性。而且,通过在 API 层面实现权限控制,可以更好地保证系统的安全性。在本文中,我们将介绍如何使用 Hapi.js 实现前后端分离以及路由级权限控制。

Hapi.js 简介

Hapi.js 是一个用于构建 Node.js 后端应用程序的框架。相比于其他框架,Hapi.js 更加注重可读性和可维护性,并且具有完善的插件机制。Hapi.js 支持路由、数据验证、插件、缓存、WebSocket 等功能,是一个非常强大的框架。

前后端分离实现

前后端分离将后端业务逻辑和前端展示逻辑分离开来,在前端展示逻辑和后端业务逻辑之间添加了一个 API 层。前端通过 API 层向后端请求数据,后端响应数据给前端。通过将前后端分离,可以实现更好的可维护性和灵活性。

创建 Hapi.js 服务

我们首先要创建一个 Hapi.js 服务并监听一个端口。代码如下:

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

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

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

运行该代码后,你就可以在 http://localhost:3000 访问我们的 Hapi.js 服务了。

创建 API 接口

接下来,我们来创建一个 API 接口。我们将创建一个 GET /api/todos 接口,用于获取待办事项列表。

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

在上面的代码中,我们定义了一个 GET /api/todos 接口,返回一个待办事项列表。我们可以通过在浏览器中访问 http://localhost:3000/api/todos 来测试我们的接口是否正常工作。

前端调用 API

在前后端分离的架构中,前端通过调用 API 来获取数据。下面的示例代码展示了如何使用 Fetch API 来调用我们的 GET /api/todos 接口:

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

在上面的代码中,我们使用 Fetch API 调用了我们的 GET /api/todos 接口,并打印出了返回的数据。你可以在浏览器的开发者控制台中运行该代码测试接口是否正常工作。

路由级权限控制实现

为了保证系统的安全性,我们需要在 API 层面实现权限控制。使用 Hapi.js 可以很方便地实现路由级别的权限控制。

创建基于角色的权限控制

首先,我们需要创建一个基于角色的权限控制系统。我们将定义两个角色:管理员和普通用户。管理员拥有所有权限,普通用户只能获取待办事项列表。代码如下:

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

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

在上面的代码中,我们定义了两个角色 adminuser,以及一个权限列表 permissions。每个 API 接口会有一个对应的权限数组,表示哪些角色拥有该接口的哪些请求方式的权限。

使用插件实现权限控制

Hapi.js 提供了一个 hapi-auth-basic 插件用于实现基于用户名和密码的身份验证。我们可以使用该插件来实现基于角色的权限控制。代码如下:

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

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

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

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

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

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

在上面的代码中,我们通过注册 hapi-auth-basic 插件来实现身份验证。然后,我们使用 server.auth.strategy 函数来定义一个名为 simple 的策略,该策略使用基本身份验证 ('basic') 和 validate 函数来验证用户身份。在 validate 函数中,我们根据用户名和密码验证用户,并设置相应的凭据和工件。在我们的示例代码中,我们模拟了不同角色的权限。

最后,我们使用 server.auth.default 函数将 simple 策略设置为默认策略,表示所有的路由都将使用该策略进行身份验证。

设置路由权限

创建完基于角色的权限控制系统后,我们需要将其应用到具体的路由上。代码如下:

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

在上面的代码中,我们将 auth 设置为在该路由上应用的身份验证配置。我们使用 access 属性来指定哪些角色可以访问该路由。在示例代码中,我们使用 permissions['/api/todos'].GET 来指定只有拥有 GET /api/todos 接口权限的角色才能访问该路由。

测试路由权限

我们可以通过浏览器和 API 请求来测试路由权限是否正常工作。对于拥有权限的访问,路由将返回待办事项列表。对于没有权限的访问,路由将返回 401 状态码和错误信息。

总结

在本文中,我们介绍了如何使用 Hapi.js 实现前后端分离和路由级权限控制。使用 Hapi.js 可以很方便地实现前后端分离,并且可以使用插件和路由配置来实现路由级权限控制,保证系统的安全性。我们希望这篇文章可以对前端开发人员提供一些实用的指导。完整示例代码可以在 GitHub 上找到。

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


猜你喜欢

  • 解决 Deno 中读取 CSV 文件的问题

    前言 在前端开发中,数据文件的读取是一个非常常见的需求,其中比较常见的一种数据格式就是 CSV(Comma-Separated Values),即逗号分隔值。 然而,在 Deno 中读取 CSV 文件...

    1 年前
  • Jest 与 Enzyme 结合进行 React 组件测试的实践

    应用于构建界面的 React 框架因为其组件化的特性和复用性,在前端圈内越来越受欢迎。与此同时,随着项目越来越大,引入测试变得越来越重要。在 React 应用中,Jest 和 Enzyme 已经成为常...

    1 年前
  • Material Design 间距规范及其对应的字符

    Material Design 是由 Google 发布的、在 Android、Web 和其他平台上都通用的设计语言,它旨在提供一致、可预测的用户界面,使用户能够快速、轻松地理解应用程序的功能和功能。

    1 年前
  • Hapi 框架使用 Boom 实现错误处理

    在前端开发中,错误处理是一个非常重要的问题。一个好的错误处理机制可以让我们更容易地调试和维护我们的应用程序,提高我们的开发效率。而 Hapi 框架的 Boom 插件可以帮助我们实现这个目标。

    1 年前
  • Docker 容器间通信技巧详解

    Docker 容器作为一个轻量级的虚拟化技术,可以快速地构建、发布和运行分布式应用程序。在分布式应用程序中,容器之间的交互和通信是非常重要的。因此,本文将详细介绍 Docker 容器间通信技巧,包括容...

    1 年前
  • 从流日志中提取和处理信息

    在前端开发中,我们经常需要从流日志中提取和处理信息。这些日志包含了我们的应用程序运行时所发生的事件,如用户交互、网络请求、错误等等。通过对这些日志进行分析,我们可以找到问题并优化我们的应用程序。

    1 年前
  • Google AMP 和响应式设计的关系与区别

    在移动设备上访问网页逐渐成为人们的主要方式,但是在移动设备上访问网页面临诸多问题,如低速的移动网络、出色的移动设备性能等。为了解决这些问题,Google 推出了 Accelerated Mobile ...

    1 年前
  • Server-sent Events 中的定时器和随机数

    在前端开发中,我们经常需要与服务器进行实时通信,从而及时获得更新后的数据。Server-sent Events(简称SSE)是一种轻量级的服务器推送技术,用于向Web客户端提供实时信息。

    1 年前
  • CSS Reset:为什么要清除默认样式?

    前言 在开发网站或者应用程序的时候,我们总是需要添加 CSS 样式表来美化我们所创建的内容。但是,不论是哪种浏览器,在加载 HTML 文件时都会有一些默认样式。比如,p 标签、li 标签和 h1 到 ...

    1 年前
  • Headless CMS 与移动端开发的共处之道

    什么是 Headless CMS? Headless CMS 是一种基于 API 的内容管理系统,它将内容管理和内容呈现分离,内容管理作为一个服务,呈现可以使用任何设备或技术来完成。

    1 年前
  • 使用 ES6 的 Promise.race 实现超时控制

    在前端开发过程中,我们经常需要对一些异步操作进行时间控制。例如,对于一个 AJAX 请求,我们希望能在一定时间内得到响应,如果等待时间过长,可能会导致用户体验不佳。

    1 年前
  • Mongoose 实现优化数据查询的技术方案

    背景: 在现代化的 web 应用程序中,数据管理非常重要,因此选择合适的数据库并进行有效的查询非常重要。Mongoose提供了一个简单而强大的方式来管理 MongoDB 数据库。

    1 年前
  • ESLint:如何规避 SyntaxError?

    在日常的前端开发中,我们经常会遇到编写代码时出现的拼写错误,语法错误等问题,这些错误不仅会影响代码的运行,还会妨碍我们的开发进度。为了避免这些问题,我们通常会使用 ESLint 进行检查和修复。

    1 年前
  • ES6 中的模板字面量详解及应用场景

    在 ECMAScript 6(以下简称 ES6)中,模板字面量是一种新的表示字符串的方式。该技术极大地改善了字符串拼接的过程,同时更加可读、易于维护。本文将详细解释 ES6 中的模板字面量的使用方法,...

    1 年前
  • 解决 RESTful API 中的身份验证与授权问题

    什么是 RESTful API REST(Representational State Transfer)是一种网络设计架构,是一种简洁轻量的风格,通过 HTTP 协议传输数据,无论语言和平台都可互通...

    1 年前
  • Socket.io 中如何自定义日志系统

    介绍 Socket.io 是一个用于实时通信的 JavaScript 库,它允许在客户端和服务器之间建立持久的双向连接。在 Socket.io 中,日志系统是非常重要的,因为通过日志可视化监控整个系统...

    1 年前
  • RxJS 高阶操作符详解

    RxJS 是一个流行的 JavaScript 库,用于操作异步数据流。在日常编码中,我们会遇到各种数据流操作需求,例如过滤、转换、合并等,这就需要使用 RxJS 高阶操作符来解决这些问题。

    1 年前
  • Vue.js 中使用 Laravel Mix 构建静态资源

    背景 Vue.js 是当前前端领域中十分热门的开发框架,而 Laravel Mix 则是 Laravel 框架中非常棒的构建工具。在使用 Vue.js 进行前端开发时,我们经常需要使用到各种静态资源,...

    1 年前
  • Fastify 使用教程:如何使用 AJV 进行数据验证

    介绍 Fastify 是一款快速且低开销的 Node.js Web 框架,可以提供高性能的路由和请求处理。AJV 是一个 JSON Schema 验证工具,可以轻松地验证 JSON 数据结构的有效性。

    1 年前
  • PWA 如何实现元素的动态加载

    Progressive Web App(PWA)是一种新兴的 Web 应用程序实现方式,旨在为用户提供更好的用户体验并支持离线访问。在PWA中,元素的动态加载是提高Web应用程序性能和用户体验的关键。

    1 年前

相关推荐

    暂无文章