原生JavaScript实现MD5、Base64与SHA256中文加密教程

需积分: 28 0 下载量 118 浏览量 更新于2024-10-07 收藏 10KB ZIP 举报
资源摘要信息:"本资源是一个压缩包文件,标题为'md5 base64 sha256加密原生js(含中文加密).zip'。压缩包内含一份JavaScript文件,该文件提供了使用原生JavaScript对字符串进行MD5、Base64和SHA-256加密的方法,并且能够处理中文字符串加密的需求。文件标题中的'原生js(含中文加密)'意味着JavaScript代码直接实现了加密算法,无需依赖外部库或框架,同时支持中文字符集的加密。 接下来,详细说明标题和描述中所提及的知识点: 1. MD5加密算法 MD5(Message-Digest Algorithm 5)是一种广泛使用的哈希算法,它可以将任意长度的数据转换为一个固定长度(128位,即16字节)的哈希值,通常用一个32位的十六进制字符串表示。MD5在安全性上已经不足以应对现代加密需求,因为它容易受到碰撞攻击,但对于一些不需要高安全级别的应用场景,如文件校验,它仍然是一个方便快捷的选择。 2. Base64编码 Base64是一种编码方法,不是加密算法。它的主要作用是将二进制数据转换成ASCII字符形式,以便在文本协议中传输。Base64编码通常用于在HTTP传输、电子邮件和HTML中嵌入图像等场景。它通过将每三个字节的二进制数据转换为四个字符的ASCII字符串来实现编码。 3. SHA-256加密算法 SHA-256(Secure Hash Algorithm 256 bit)属于SHA-2系列的哈希算法之一,能够生成一个256位(即32字节)的哈希值。SHA-256比MD5提供了更高的安全性和抗碰撞性,目前广泛应用于安全相关的场合,例如数字签名和SSL/TLS证书。 4. JavaScript中的加密实现 原生JavaScript支持基本的字符串操作和正则表达式处理,但并不内置加密算法的实现。通常需要通过算法库如CryptoJS来实现加密功能。然而,通过一些数学运算和字符编码技术,可以在不依赖任何第三方库的情况下在JavaScript中手动实现上述加密算法。 5. 中文字符串加密 当使用JavaScript对中文字符进行加密时,需要特别注意字符编码问题。由于JavaScript内部处理的字符是以UTF-16编码为基础的,而加密算法通常基于字节流,因此需要在加密前将中文字符串转换为适合加密算法处理的格式,通常是UTF-8编码,然后再进行加密处理。 使用方法中提到的三个函数: - sha256_digest(string):这个函数接收一个字符串参数,并返回其SHA-256哈希值。 - md5(string):这个函数接收一个字符串参数,并返回其MD5哈希值。 - Base64.toBase64(string):这个函数接收一个字符串参数,并返回其Base64编码后的字符串。 文件名称列表中提到的文件名'原生js(含中文加密)',可能暗示着JavaScript文件中包含了上述三种方法的实现,并能够处理中文字符的加密问题。 综上所述,本压缩包文件提供了一套使用原生JavaScript实现的加密解密工具,适用于需要在客户端实现简单加密功能的Web应用,但需要注意的是,对于需要高安全级别的应用场景,建议使用更加安全的加密算法和协议。"

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 createSha256 = CryptoJs.algo.SHA256.create() // SHA256 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) createSha256.update(wordArray) createMD5.update(wordArray) createSha256Uint8Array32.update(chunk) offset += chunkSize // 计算进度 // const progress = Math.min(100, Math.round((offset / fileSize) * 100)) // console.log(progress) // 打印进度 // postMessage({ progress, offset, fileSize, }) // 将进度发送给主线程 } const [sha256Uint8Array32, sha256, md5] = await Promise.all([ createSha256Uint8Array32.digest(), // SHA256 Unit8Array(32) encHex.stringify(createSha256.finalize()), // SHA256 Hex encHex.stringify(createMD5.finalize()), // MD5 ]) const obj = { md5, // MD5 sha256, // SHA256 Hex sha256Int8Array32: Array.from(new Int8Array(sha256Uint8Array32)), // SHA256 Int8Array(32) } console.log(obj) // 打印结果对象 postMessage(obj) // 将结果对象发送给主线程 } 加功能计算文件sha1

2023-06-06 上传