|
3 ヶ月 前 | |
---|---|---|
.. | ||
benchmark | 3 ヶ月 前 | |
LICENSE.txt | 3 ヶ月 前 | |
readme-CN.md | 3 ヶ月 前 | |
rsa-CN.md | 3 ヶ月 前 |
crypto-js-wasm
是基于 JavaScript 和 WebAssembly 的哈希与加密算法库,其灵感来自于crypto-js。
浏览器
和 nodejs
当前已经支持RSA和TypeScript!
npm install @originjs/crypto-js-wasm
或
pnpm install @originjs/crypto-js-wasm
或
yarn add @originjs/crypto-js-wasm
在使用各算法前需调用一次对应的loadWasm()
,或调用loadAllWasm()
以加载所有算法的WebAssembly文件。
import CryptoJSW from '@originjs/crypto-js-wasm';
// (可选) 加载所有 wasm 文件
await CryptoJSW.loadAllWasm();
// 通过 Async/Await 语法调用
await CryptoJSW.MD5.loadWasm();
const rstMD5 = CryptoJSW.MD5('message').toString();
console.log(rstMD5);
// 通过 Promise 语法调用
CryptoJSW.SHA256.loadWasm().then(() => {
const rstSHA256 = CryptoJSW.SHA256('message').toString();
console.log(rstSHA256);
})
wasm加载,其中wb变量为wasm二进制文件的base64编码文本
// 加载 WebAssembly 模块
const wasmModule = new WebAssembly.Module(Uint8Array.from(atob(wb), c => c.charCodeAt(0)));
需要注意的是,HMAC
没有loadWasm
,因为如果要使用HMAC
,必须指定哈希(例如HmacSHA1
)。
同时, pbkdf2
中的 loadWasm
实现是调用了 SHA1.loadWasm
,这是因为 SHA1
是 pbkdf2
的默认哈希算法。 如果指定了另一个哈希算法,则应分别调用该哈希算法对应的 loadWasm
。 evpkdf
/MD5
的情况与之类似, MD5
是 evpkdf
的默认哈希算法。
RSA使用说明
请参考这篇文档.
目前可用的算法
RC4Drop
RSA
以下 benchmark 结果运行自一台台式机 (i5-4590, 16 GB RAM, Windows 10 Version 21H2 (OSBuild 19044, 1466))。
Chrome 102.0.5005.63:
Firefox 101.0:
Nodejs v16.6.4:
RSA(vs jsencrypt) in Chrome:
# 安装依赖
pnpm install
# 生产构建
pnpm run build
# 运行所有测试
pnpm run test
# 运行所有测试并生成测试覆盖率报告
pnpm run coverage
这是因为 WebAssembly 二进制需要通过 WebAssembly.instantiate
加载,并且这是一个异步函数。
WebAssembly.instantiate
与它的同步实现 WebAssembly.instance
相比,前者更受推荐;并且,在许多场景下,WebAssembly.instance
无法加载不够小的 WebAssembly 二进制。
因为 crypto-js-wasm
需要同时支持 browser
和 nodejs
两种使用场景。相比与 browser
中的 wasm loader
(多数情况下由 webpack, vite 或其他框架提供)以及 nodejs
中的 fs
方式,这种wasm二进制存储方式是一种相对优雅的方式。
该项目遵守木兰宽松许可证