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
时间: 2024-03-06 19:47:37 浏览: 151
你的代码中已经计算了文件的 MD5、SHA1、SHA256 和 SHA512 值,并且将结果存储在了一个对象中。如果你要计算文件的 CRC32 值,可以使用一些第三方库来实现。
以下是一个使用 `crc32` 库计算文件 CRC32 值的示例代码:
```javascript
import { Sha256 } from '@aws-crypto/sha256-js'
import CryptoJs from 'crypto-js'
import encHex from 'crypto-js/enc-hex'
import crc32 from 'crc32'
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
let crc = 0 // CRC32 值
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)
crc = crc32(chunk, crc) // 计算 CRC32 值
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)
crc32: crc.toString(16), // CRC32 值
}
console.log(obj) // 打印结果对象
postMessage(obj) // 将结果对象发送给主线程
}
```
在上面的代码中,我们引入了 `crc32` 库,并在每次读取文件块时调用 `crc32` 函数计算 CRC32 值。计算完成后,将 CRC32 值添加到结果对象中,并通过 `postMessage` 函数将结果对象发送给主线程。
阅读全文