1 概述

jsSHA是一个用JS+TS实现完整SHA系列加密算法的加密库,包括:

  • SHA1
  • SHA-224/256/384/512
  • SHA3-224/256/384/512
  • SHAKE128/256
  • cSHAKE128/256
  • KMAC128/256

官方Github戳这里,目前已有2k的star,这里是一些使用加密算法的例子。

2 安装并引入

安装使用npmcnpm

npm install --save jssha
# 或
cnpm install --save jssha

引入时,根据package.json中的type进行相应引入:

const jsSHA = require("jssha") //commonjs
import jsSHA from "jssha" //module

若为

"type":"commonjs"

则使用

const jsSHA = require("jssha")

3 哈希

一个简单的例子如下:

const jsSHA = require("jssha")
const shaObj = new jsSHA("SHA-512","TEXT",{encoding:"UTF8"}) shaObj.update("test")
console.log(shaObj.getHash("HEX"))

首先声明了一个shaObj,通过update传递明文,并通过getHash("HEX")即得到哈希值,另外update可以调用多次,最后使用getHash即可。

jsSHA()有三个参数:哈希算法、输入格式以及参数设置(可选)。

3.1 哈希算法

第一个参数是哈希算法,支持的算法如下:

  • SHA-1
  • SHA-224
  • SHA-256
  • SHA-384
  • SHA-512
  • SHA3-224
  • SHA3-256
  • SHA3-384
  • SHA3-512
  • SHAKE128
  • SHAKE256

目前不建议使用SHA-1,建议使用SHA-2SHA-224、256/384/512)或SHA-3SHA3-224/256/384/512)。

SHAKESecure Hash Algorithm and KECCAK的缩写,在FISP 202标准中定义,与SHA-3类似,但是输出是无限位数的。因此定义的时候需要指定输出的位数,不然的话会得到如下报错:

getHash中加上参数即可:

const jsSHA = require("jssha")
const shaObj = new jsSHA("SHAKE128","TEXT",{encoding:"UTF8"}) shaObj.update("test")
console.log(shaObj.getHash("HEX",{outputLen:1024}))

3.2 输入格式

输入格式的取值如下:

  • HEX
  • TEXT
  • B64
  • BYTES
  • ARRAYBUFFER
  • UNIT8ARRAY

3.3 参数选项

一般常用两个:

  • encoding:编码,允许取值UTF8/UTF16BE/UTF16LE
  • numRounds:哈希轮数

其他的参数可以查看源码。

3.4 getHash

getHash是获取哈希结果的函数,第一个参数可以是:

  • HEX
  • B64
  • BYTES
  • UINT8ARRAY
  • ARRAYBUFFER

与上面的输入格式对应,可以带上输出长度选项,对于HEX可以带上outputUpper表示是否大写:

4 HMAC

HMAC是一种基于哈希函数和密钥进行消息认证的方法,使用时需要指定密钥:

const jsSHA = require("jssha")
const shaObj = new jsSHA("SHA3-512","TEXT",{
hmacKey:{value:'secret key',format:'TEXT'}
}) shaObj.update("test")
console.log(shaObj.getHash("HEX"))

5 cSHAKE

cSHAKE可以看作一个"定制版"的SHAKE,需要使用额外的customization参数:

const jsSHA = require("jssha")
const shaObj = new jsSHA("CSHAKE128","TEXT",{
customization:{value:"test",format:"TEXT"}
}) shaObj.update("test")
console.log(shaObj.getHash("HEX",{outputLen:1024}))

6 KMAC

KMACKECCAK Message Authentication Code)是一个基于KECCAK的算法,需要提供 kmacKey`参数:

const jsSHA = require("jssha")
const shaObj = new jsSHA("KMAC128","TEXT",{
kmacKey:{value:"secret key",format:"TEXT"}
}) shaObj.update("test")
console.log(shaObj.getHash("HEX",{outputLen:1024}))

最新文章

  1. 使用免费组件view pdf 文档
  2. Linux系统目录结构
  3. HDU-Minimum Inversion Number(最小逆序数)
  4. POJ 2516:Minimum Cost(最小费用流)
  5. Open vSwitch使用案例扩展实验
  6. ActiveMQ消息的可靠性机制(转)
  7. MySQL 5 绿色版(BAT版本) mysql50green转自http://hi.baidu.com/dburu/blog/item/e753fcc4362458aa8226accb.htmlMySQL 5 绿色版(BAT版本) By )
  8. C166 Interfacing C to Assembler
  9. Java 多线程的基本概念
  10. 对PostgreSQL xmin的深入学习
  11. Google前工程经理王忻:如何准备软件工程师的面试
  12. Javascript的块级作用域
  13. 自己的第一个android应用(天气)
  14. MongoDB-python的API手记
  15. Java单例模式(Singleton)以及实现
  16. EECS 649 Introduction to Artificial Intelligence
  17. hibernate NUMBER 精度
  18. 神经网络参数与TensorFlow变量
  19. 2019-04-04-day026-模块和包的导入
  20. Oracle EBS OPM 事务处理

热门文章

  1. 16_MySQL聚合函数的使用(重点,建议大家多动手操作)
  2. 工作之余第二篇(看源码自己实现ArrayList和LinkList)
  3. C#语言特性及发展史
  4. Java编程开发之数据图表分析模型
  5. c++指针类型的函数
  6. win10使用cmd命令关闭防火墙
  7. js和c#小数四舍五入
  8. java 流程控制学习
  9. Java 常见对象 03
  10. JS table排序