npm 包 hashing 使用教程

什么是 hashing?

hashing 是一种用于固定字符串长度的技术,在前端开发中经常用于构建缓存键、数据签名等需求。比如我们可以把一个长长的 url 地址通过 hashing 转成一个定长的字符串,作为本地缓存的键值,或者把一个传输的数据加上一个 hash 校验码,确保数据的完整性。

npm 包 hashing 介绍

npm 上有许多好用的 hashing 相关的包,比如 crypto-js, hash.js 等,今天我们主要介绍一个叫做 hasha 的 npm 包,它非常轻量,只有几十个 KB 的体积,同时支持多种 hashing 算法,包括 md5, sha256, sha512 等等。

以下是安装 hasha 的命令:

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

如何使用 hasha?

hasha 支持两种常见的使用场景,一是对字符串进行 hash,二是对文件进行 hash。

对字符串进行 hash:

我们通过以下代码,对一个字符串 "hello world" 进行 md5 算法的 hashing:

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

其中,algorithm 参数指定了使用的 hashing 算法,这里我们选择了 md5。

对文件进行 hash:

我们通过以下代码,对一个文件的内容进行 sha1 算法的 hashing:

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

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

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

其中,我们先通过 fs 模块读取了文件内容,然后直接将内容传给 hasha 函数进行 hashing。

多个文件进行批量 hash:

我们通过以下代码,对多个文件进行 sha1 算法的批量 hashing:

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

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

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

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

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

我们通过遍历文件夹中的文件名,然后读取每个文件的内容,最后将每个文件的 hash 值保存在一个对象中返回。

示例说明

我们通过以上示例可以看到,使用 hasha 包进行 hashing 无比方便。我们可以在字符串和文件层面,以及批量 hash 多个文件层面,进行各种 hashing 算法的计算。

在前端开发中,hashing 技术有广泛的应用场景,比如缓存键、数据签名、网站静态资源版本控制以及防篡改等方面,这里我们只列举了一些最基本的示例,希望可以为你的开发提供一些启示和借鉴价值。

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


猜你喜欢

  • npm 包 prueba-dependencia 使用教程

    在前端开发中,使用 npm 来安装和管理包已经成为了标配。其中,prueba-dependencia 是一个非常实用的 npm 包,本文将详细介绍它的使用方法。 什么是 prueba-dependen...

    3 年前
  • npm 包 @shoutem/fork-terminal 使用教程

    什么是 @shoutem/fork-terminal @shoutem/fork-terminal 是一个基于 Node.js 的 npm 包,它可以帮助我们在前端环境中,以类似终端的方式运行 Jav...

    3 年前
  • npm 包 `los-auth-mobile` 使用教程

    los-auth-mobile 是一个用于移动端的认证库,它可以帮助开发者快速集成手机号/验证码/密码登录、注册、找回密码等认证流程。该库已经在众多移动应用中得到广泛使用,具有稳定、易用等优点。

    3 年前
  • npm 包 insertion-sort-ascending 使用教程

    insertion-sort-ascending 是一个 npm 包,可以帮助我们进行插入排序。本文将介绍该插件的使用教程,包括安装、基本使用和高级使用。 安装 插件的安装非常简单,只需要打开终端,进...

    3 年前
  • npm 包 insertion-sort-descending 使用教程

    简介 insertion-sort-descending 是一个用于降序排序的 npm 包。它使用插入排序算法来对数组元素进行排列,并且可以自定义排序的顺序(升序或降序)。

    3 年前
  • NPM 包 open-anais 使用教程

    简介 open-anais 是一个用于打开指定网址或本地文件的 Node.js 模块。通过该模块,可以方便地在命令行或 JavaScript 代码中打开指定 URL 或本地文件夹。

    3 年前
  • NPM包vue-demo-test使用教程

    在前端开发中,使用NPM包可以很方便地管理和引用第三方库、框架及插件。其中,Vue.js是非常受欢迎的前端框架之一,本文将介绍一个基于Vue.js的NPM包vue-demo-test的使用教程,帮助初...

    3 年前
  • npm 包 react-bootstrap-table-coreui 使用教程

    前言 在前端开发中,表格是一个非常重要的组件,而 react-bootstrap-table-coreui 是一个功能强大的 React 表格库,它提供了许多实用的功能,例如分页、排序、过滤等等,并且...

    3 年前
  • npm 包 vusion-webfonts-generator 使用教程

    在前端开发中,web 字体是一个非常重要的元素。它能够让你的网站或应用程序看起来更加漂亮和专业。但是在使用 web 字体时,有时候我们需要将多个字体合成一个文件,以便减少网络请求次数。

    3 年前
  • npm 包 @1amageek/flow 使用教程

    简介 在前端开发中,数据的流动和状态的管理是非常重要的。而 JavaScript 的函数式编程范式为我们提供了很好的解决方式,其中一种就是使用流(Stream)来描述数据的流动。

    3 年前
  • npm 包 @beradrian/ngx-auto-scroll 使用教程

    什么是 @beradrian/ngx-auto-scroll @beradrian/ngx-auto-scroll 是一个 Angular 插件,用于在滚动容器中自动滚动到底部。

    3 年前
  • NPM 包 @appcarvers/jangular 使用教程

    在前端开发中,使用 NPM 包可以大大提高开发效率和代码质量。其中,@appcarvers/jangular 是一个功能强大的 AngularJS 模板引擎,它可以实现模板的继承、组件化开发、自定义指...

    3 年前
  • npm 包 key-locker 使用教程

    Key-locker 是一款方便管理加密密钥的 npm 包。通过 key-locker,我们可以轻松地对密钥进行加密、解密、保存和读取等操作。 安装 在使用 key-locker 之前,我们需要先安装...

    3 年前
  • npm 包 ng2-opentok 使用教程

    前言 随着实时通信技术的发展,对于前端开发工程师而言,实时音视频通信已经成为了一个重要的应用场景。本文将介绍如何使用 npm 包 ng2-opentok 实现实时音视频通信的功能。

    3 年前
  • npm 包 insertion-sort-algorithm 使用教程

    在前端开发中,排序算法是一项非常重要的技能。而 insertion sort(插入排序)是其中最基础的一种算法之一,也是相对简单易学且在实际应用中较为常见的一种排序算法。

    3 年前
  • npm 包 mdm-cmd-poc 使用教程

    介绍 mdm-cmd-poc 是一个基于 Node.js 的命令行工具,用于提取和呈现 Markdown 文件中的代码块,支持实时预览和语法高亮。使用 mdm-cmd-poc 可以轻松地将 Markd...

    3 年前
  • NPM包platzomlaguaje使用教程

    NPM (Node Package Manager) 是 Node.js 中的包管理工具。它允许您在您的项目中使用和共享代码包。platzomlaguaje是一个NPM包,可以对西班牙语进行转换。

    3 年前
  • npm 包 vue-calendar-picker 使用教程

    前言 随着前端技术的不断发展,越来越多的工具和框架被开发出来。其中,vue-calendar-picker 是一款 Vue.js 的日历选择器组件,可以用于日历的展示和日期的选择。

    3 年前
  • npm 包 @progress/jsdo 使用教程

    在前端开发中,与后端进行数据交互是必不可少的一环。而 @progress/jsdo 就是一个优秀的用于与后端进行数据交互的 npm 包。本文将详细地介绍 @progress/jsdo 的使用方法和具体...

    3 年前
  • npm 包 egg-istanbul-middleware 使用教程

    在前端开发中使用测试工具进行测试是非常必要的步骤,而在测试覆盖率的评估中,istanbul 是非常重要的工具。而 egg-istanbul-middleware 这一 npm 包则提供了在 egg.j...

    3 年前

相关推荐

    暂无文章