JavaScript SHA512与SHA256加密算法实现解析

1 下载量 166 浏览量 更新于2024-09-03 收藏 56KB PDF 举报
本文主要介绍了JavaScript中的SHA512和SHA256加密算法,提供了相关的JavaScript实现代码,包括SHA512的详细代码,并提到了适用于这两种算法的字符串转换函数。 SHA(Secure Hash Algorithm)是一种广泛使用的密码学散列函数,其中SHA-512和SHA-256是两种不同版本的算法。SHA-512产生一个512位(64字节)的散列值,而SHA-256则产生一个256位(32字节)的散列值。这些算法的主要目的是将任意长度的数据转化为固定长度的摘要,这个摘要对原始数据极其敏感,微小的改变都会导致散列值的巨大变化,因此常用于验证数据的完整性和防止篡改。 在JavaScript中实现SHA512加密算法,通常需要以下几个步骤: 1. **字符串到字节数组的转换**:由于JavaScript处理字符串时默认是UTF-8编码,因此在进行散列之前,需要将字符串转换为字节数组。在提供的代码中,`str2rstr_utf8`函数就是完成这个转换的。 2. **SHA512核心算法**:在给出的代码中,`rstr_sha512`函数实现了SHA-512的核心算法,它接受一个字节数组作为输入,然后按照SHA-512的计算规则进行迭代和混合,最终得到512位的散列结果。 3. **散列结果的转换**:生成的散列值通常是二进制形式,为了方便展示和使用,可能需要将其转换为十六进制或Base64编码。在代码中,`rstr2hex`和`rstr2b64`函数分别用于将字节数组转换为十六进制字符串和Base64编码。 4. **HMAC-SHA512**:HMAC(Hash-based Message Authentication Code)是一种基于密钥的哈希函数,用于生成一个消息认证码,提供数据完整性和来源认证。在提供的代码中,`hex_hmac_sha512`函数实现了HMAC-SHA512,它需要两个参数:一个密钥(key)和一个数据(data),返回的结果是十六进制表示的HMAC。 此外,代码中还有一些可配置的变量,如`hexcase`控制输出的十六进制字符是否大写,`b64pad`是Base64编码的填充字符。这些可以根据实际需求进行调整。 JavaScript中的SHA512和SHA256加密算法实现涉及了字符串处理、散列计算和编码转换等多个方面,对于网络安全和数据保护有着重要的应用。在实际开发中,可以使用这些算法来加密敏感信息,或者创建数字签名来验证数据的完整性和真实性。

import { Sha256 } from '@aws-crypto/sha256-js' import CryptoJs from 'crypto-js' import encHex from 'crypto-js/enc-hex' onmessage = async function (event) { const data = event.data // 获取文件数据 // chunk方式读取文件 const chunkSize: number = 1024 * 1024 // 每次读取1MB const fileSize: number = data.size // 文件大小 let offset: number = 0 // 偏移量 const createSha256Uint8Array32 = new Sha256() // SHA256 Unit8Array(32) const createSha1 = CryptoJs.algo.SHA1.create() // SHA1 Hex const createSha256 = CryptoJs.algo.SHA256.create() // SHA256 Hex const createSha512 = CryptoJs.algo.SHA512.create() // SHA512 Hex const createMD5 = CryptoJs.algo.MD5.create() // MD5 while (offset < fileSize) { const chunk = new Uint8Array(await data.slice(offset, offset + chunkSize).arrayBuffer()) // 读取chunkSize大小的文件块 const wordArray = CryptoJs.lib.WordArray.create(chunk) createSha256Uint8Array32.update(chunk) createSha1.update(wordArray) createSha256.update(wordArray) createSha512.update(wordArray) createMD5.update(wordArray) offset += chunkSize // 计算进度 // const progress = Math.min(100, Math.round((offset / fileSize) * 100)) // 计算进度 // console.log(progress) // 打印进度 // postMessage({ progress, offset, fileSize }) // 将进度发送给主线程 } const [sha256Uint8Array32, sha1, sha256, sha512, md5] = await Promise.all([ createSha256Uint8Array32.digest(), // SHA256 Unit8Array(32) encHex.stringify(createSha1.finalize()), // SHA1 Hex encHex.stringify(createSha256.finalize()), // SHA256 Hex encHex.stringify(createSha512.finalize()), // SHA512 Hex encHex.stringify(createMD5.finalize()), // MD5 ]) const obj = { md5, // MD5 sha1, // SHA1 Hex sha256, // SHA256 Hex sha512, // SHA512 Hex sha256Int8Array32: Array.from(new Int8Array(sha256Uint8Array32)), // SHA256 Int8Array(32) } console.log(obj) // 打印结果对象 postMessage(obj) // 将结果对象发送给主线程 } 增加功能计算 sm3

2023-06-07 上传

import { Sha256 } from '@aws-crypto/sha256-js' import CryptoJs from 'crypto-js' import encHex from 'crypto-js/enc-hex' onmessage = async function (event) { const data = event.data // 获取文件数据 // chunk方式读取文件 const chunkSize = 1024 * 1024 // 每次读取1MB const fileSize = data.size // 文件大小 let offset = 0 // 偏移量 const createSha256Uint8Array32 = new Sha256() // SHA256 Unit8Array(32) const createSha1 = CryptoJs.algo.SHA1.create() // SHA1 Hex const createSha256 = CryptoJs.algo.SHA256.create() // SHA256 Hex const createSha512 = CryptoJs.algo.SHA512.create() // SHA512 Hex const createMD5 = CryptoJs.algo.MD5.create() // MD5 while (offset < fileSize) { const chunk = new Uint8Array(await data.slice(offset, offset + chunkSize).arrayBuffer()) // 读取chunkSize大小的文件块 const wordArray = CryptoJs.lib.WordArray.create(chunk) createSha256Uint8Array32.update(chunk) createSha1.update(wordArray) createSha256.update(wordArray) createSha512.update(wordArray) createMD5.update(wordArray) offset += chunkSize // 计算进度 // const progress = Math.min(100, Math.round((offset / fileSize) * 100)) // console.log(progress) // 打印进度 // postMessage({ progress, offset, fileSize, }) // 将进度发送给主线程 } const [sha256Uint8Array32, sha1, sha256, sha512, md5] = await Promise.all([ createSha256Uint8Array32.digest(), // SHA256 Unit8Array(32) encHex.stringify(createSha1.finalize()), // SHA1 Hex encHex.stringify(createSha256.finalize()), // SHA256 Hex encHex.stringify(createSha512.finalize()), // SHA512 Hex encHex.stringify(createMD5.finalize()), // MD5 ]) const obj = { md5, // MD5 sha1, // SHA1 Hex sha256, // SHA256 Hex sha512, // SHA512 Hex sha256Int8Array32: Array.from(new Int8Array(sha256Uint8Array32)), // SHA256 Int8Array(32) } console.log(obj) // 打印结果对象 postMessage(obj) // 将结果对象发送给主线程 } 加功能计算文件 crc32

2023-06-06 上传
2023-05-30 上传