使用js验证hash,content hash , chunk hash的区别解析

 更新时间:2024年12月07日 09:55:38   作者:silvia_frontend  
crypto-js是一个JavaScript加密算法库,用于实现各种加密算法和哈希函数,它提供了一种简单而强大的方式来执行加密操作,包括对称加密算法、非对称加密算法和哈希函数等,本文给大家介绍使用js验证hash,content hash , chunk hash的区别解析,感兴趣的朋友跟随小编一起看看吧

一、使用js验证hash, content hash , chunk hash的区别

1、计算一般的 Hash(以简单字符串为例)

使用crypto-js库来进行哈希计算,需提前引入npm install crypto-js库。

crypto-js: 是一个JavaScript加密算法库,用于实现各种加密算法和哈希函数,它提供了一种简单而强大的方式来执行加密操作,包括对称加密算法、非对称加密算法和哈希函数等。

  • 实现:这里以一个简单字符串来验证,使用CryptoJS.SHA256进行加密, 字符串改变,生成的加密值肯定不同。
  • 应用:一般开发登录模块的时候会用到,服务端存储的是这个哈希值,当再次登录输入密码时,会再次计算密码的哈希值,并和存储的哈希值做比较。
const CryptoJS = require("crypto-js");
// Hash
const password = "this is my passward 1234";
const hash = CryptoJS.SHA256(password).toString();
console.log("Hash:", hash);

2、计算 Content Hash(基于文本内容整体的哈希)

首先准备一个txt文件,然后通过fs读取文件内容。
text.txt:

这是一段测试的文本!!!
11111111111111111
222222222
3333333333
44444444

fs模块: Node.js提供的对系统文件及目录进行读写操作的模块。
fs.readFile(filename,[option],callback) 方法读取文件。

  • 实现:加密方法还是和上面的一样,只不过是通过fs获取的文件内容。可以看到,内容哈希关注的是文件内容本身的完整性。如果文件内容发生变化,内容哈希值也会随之改变。
  • 场景:在内容分发网络(CDN)中判断资源是否更新等场景,只要内容没变化,内容哈希值就不会变。
const CryptoJS = require("crypto-js");
const fs = require("fs");
// Content Hash
fs.readFile("src/test.txt", "utf-8", (err, data) => {
    if (err) {
        console.error("Error reading file:", err);
        return;
    }
    const contentHash = CryptoJS.SHA256(data).toString();
    console.log("Content Hash: ", contentHash);
});

3、计算 Chunk Hash(将内容分块后计算哈希)

和上面内容哈希的获取方式一样,只不过需要将获取到的文件划分成多个chunk,然后对每个chunk进行加密。

const CryptoJS = require("crypto-js");
const fs = require("fs");
// Chunk Hash
const CHUNK_SIZE = 10; // 每个块的大小(字节)
fs.readFile("src/test.txt", "utf-8", (err, data) => {
    if (err) {
        console.log("err", err);
        return;
    }
    const chunkHashes = []; // 块hash值数组
    for (let i = 0; i < data.length; i += CHUNK_SIZE) {
        const chunkContent = data.slice(i, i + CHUNK_SIZE);
        const chunkHash = CryptoJS.SHA256(chunkContent).toString();
        chunkHashes.push(chunkHash);
    }
    console.log("Chunk Hashes", chunkHashes);
});

slice()方法:是 JavaScript 中用于提取字符串或数组部分内容的方法。它返回一个新的字符串或数组,包含从原字符串或数组中提取的部分元素,原字符串或数组本身不会被修改。

语法string.slice(startIndex[, endIndex])。其中startIndex是提取的起始位置(索引从 0 开始),endIndex是提取的结束位置(不包括该位置的字符)。如果省略endIndex,则提取从startIndex到字符串末尾的部分。

改变txt文件中的后面一点内容,然后观察到前面的chunk的hash都没变,只有后面的两个hash改变了。

场景:这种块哈希的计算方式常用于大型文件传输等场景,在传输或存储过程中可以分别验证每个块的完整性,通过对比每个块的哈希值与原始的块哈希是否一致来判断块数据是否准确。

二、webpack配置中这三种hash的作用分析

1、Hash(模块标识符哈希)

在webpack中,hash是基于整个构建内容(包括所有模块、资源等)生成的一个哈希值,每次构建时,只要一个文件改变,这个哈希值就会改变。

module.exports = { 
    //...其他配置 
    output: { filename: '[name].[hash:8].js' }  //:8就是指定生成的hash值是8位的
};
  • 优点: 简单直接,可以用于版本控制和缓存清除。当新的构建发生时,由于hash值改变,浏览器会重新下载新的资源文件,保证用户获取到最新的内容。
  • 缺点: 比如即使一个css文件一个小改动,重新构建时哈希值都会改变,可能导致不必要的缓存失效,影响性能。

2、Content Hash(内容哈希)

在webpack中,content-hash是根据文件内容(具体模块或资源的内容)生成的哈希值。它只和文件自身的内容有关,与其他文件或构建过程中的其他因素无关。

module.exports = { 
    //...其他配置 
    output: { filename: '[name].[contenthash].js' } 
};

优点: 精确地基于内容进行哈希计算,使得只有内容发生变化的文件,其文件名才会改变。这对于缓存管理非常有利。缺点: 计算成本相对较高,因为需要对每个文件内容进行单独的哈希计算。不过,在现代构建工具和硬件条件下,这个缺点通常可以接受。

3、Chunk Hash(块哈希)

在webpack中,chunk-hash是基于 Webpack 打包后的代码块(chunk)生成的哈希值。Webpack 在打包过程中会将相关的模块组合成代码块,chunk-hash就是针对这些代码块进行计算的。

module.exports = { 
    //...其他配置 
    output: { filename: '[name].[chunkhash].js' } 
};
  • 优点: 可用于代码分割(code-splitting)场景。如:一个 Web 应用有多个入口点(如main.jsvendor.js),通过chunk-hash可以为每个入口点对应的代码块生成独立的哈希值。这样,当一个代码块(如vendor.js包含第三方库)的内容没有变化时,其对应的文件名不会因为其他代码块(如main.js)的变化而改变,有利于浏览器缓存的有效利用。
  • 缺点: 如果代码块的划分发生变化(例如,调整了 Webpack 的代码分割策略),即使模块内容没有改变,chunk-hash值也可能会改变,从而影响缓存。

这篇文章我们通过js验证了一下hash, content hash , chunk hash的区别,并对比了一下webpack中的使用场景,希望对对webpack这里配置有疑惑的伙伴有帮助。

到此这篇关于使用js验证hash, content hash , chunk hash的区别的文章就介绍到这了,更多相关js验证hash, content hash , chunk hash内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 9102了,你还不会移动端真机调试吗

    9102了,你还不会移动端真机调试吗

    这篇文章主要介绍了9102了,你还不会移动端真机调试吗,本文详细的介绍了3种移动端真机调试方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • js 打开新页面在屏幕中间的实现方法

    js 打开新页面在屏幕中间的实现方法

    下面小编就为大家带来一篇js 打开新页面在屏幕中间的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • 深入理解选择框脚本[推荐]

    深入理解选择框脚本[推荐]

    选择框是通过<select>和<option>元素创建的,又称为下拉列表框。为了方便与这个控件交互,除了所有表单字段共有的属性和方法外,javascript还提供了一些属性和方法。本文将详细介绍选择框脚本
    2016-12-12
  • JS实现快递单打印功能【推荐】

    JS实现快递单打印功能【推荐】

    这篇文章主要介绍了JS实现快递单打印功能,给大家介绍了js网页打印的几种方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-06-06
  • JavaScript 程序执行顺序问题总结

    JavaScript 程序执行顺序问题总结

    今天总结下学习和开发中遇到的JavaScript执行顺序的问题,今天挖个坑,以后会慢慢填,也希望抛砖引玉,能学到更多的东西。
    2011-06-06
  • JavaScript对象的特性与实践应用深入详解

    JavaScript对象的特性与实践应用深入详解

    这篇文章主要介绍了JavaScript对象的特性与实践应用,结合实例形式较为深入的分析了javascript对象的相关概念、操作方法及注意事项,需要的朋友可以参考下
    2018-12-12
  • Echarts图例组件的属性与源代码

    Echarts图例组件的属性与源代码

    图例组件展现了不同系列的标记(symbol),颜色和名字,可以通过点击图例控制哪些系列不显示,这篇文章主要给大家介绍了关于Echarts图例组件的相关资料,需要的朋友可以参考下
    2021-06-06
  • JavaScript ES6常用基础知识总结

    JavaScript ES6常用基础知识总结

    ES6中为我们提供了很多好用的新特性,其中包括let,箭头函数以及扩展运算符…等,以下就是总结的常用基础知识
    2019-02-02
  • 原生js如何实现call,apply以及bind

    原生js如何实现call,apply以及bind

    这篇文章主要介绍了原生js实现call,apply以及bind,帮助大家更好的理解和学习使用JavaScript,感兴趣的朋友可以了解下
    2021-04-04
  • 前端必会的Webpack优化技巧

    前端必会的Webpack优化技巧

    这篇文章主要为大家介绍了前端必会的Webpack优化技巧示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07

最新评论