首页 > 其他分享 >Vite打包zip并改名为md5sum哈希案例

Vite打包zip并改名为md5sum哈希案例

时间:2024-09-17 08:56:01浏览次数:10  
标签:fs const zip md5sum 哈希 Vite MD5

通常在DevOps CICD流水线部署前端项目时,一般默认都要将dist资源打包为zip,并且把zip名称改为md5sum哈希值(用于文件完整性验证)。

md5sum是什么?

md5sum 是一个在 Unix 和类 Unix 系统(如 Linux)中广泛使用的命令行工具,它主要用于计算和验证文件的 MD5 哈希值。MD5(Message-Digest Algorithm 5)是一种广泛使用的加密哈希函数,可以产生一个128位(16字节)的哈希值(通常以一个32位的十六进制数表示)。md5sum 工具的主要用途包括:

  1. 文件完整性验证:通过计算文件的 MD5 哈希值,可以验证文件在传输或存储过程中是否被篡改。如果文件的 MD5 哈希值在传输前后一致,那么可以认为文件在传输过程中未被更改。
  2. 软件分发:在软件分发过程中,开发者会提供软件的 MD5 哈希值。用户下载软件后,可以使用 md5sum 计算下载文件的 MD5 哈希值,并与开发者提供的哈希值进行比较,以确保下载的软件包完整且未被篡改。
  3. 备份验证:在备份文件或目录时,使用 md5sum 可以为每个备份文件生成一个 MD5 哈希值,并保存这些哈希值。之后,可以通过重新计算备份文件的 MD5 哈希值来验证备份的完整性和一致性。
  4. 数据去重:虽然这不是 md5sum 的主要用途,但由于 MD5 哈希值对于相同的输入总是产生相同的输出,因此可以用于快速检测数据集中的重复项。然而,由于 MD5 的安全性问题(如存在碰撞攻击),这种方法在需要高度安全性的场合并不适用。
  5. 简单加密:虽然 MD5 并不适合用于加密(因为它是一个单向哈希函数,无法从哈希值恢复原始数据),但在某些简单场景下,MD5 哈希值可以用于生成一种简单的“密码”或校验码,尽管这种方式的安全性较低。

Vite对应代码简单案例:

1,我们使用vite-plugin-zip-pack和crypto插件

npm i vite-plugin-zip-pack -D

npm i crypto -D

2,Vite配置代码

// vite.config.ts
import fs from "fs";
import path from "path";
import crypto from "crypto";

export default defineConfig({
    plugins: [
        //...
        zipPack({
            inDir: "dist",
            outDir: "zip/", // zip存放路径
            outFileName: "dist.zip", // 默认名称为dist
            done: () => {
                // zip路径
                const originPath = "zip/";
                const originFilePath = `${originPath}dist.zip`;
                // 读取zip内容
                const fileContents = fs.readFileSync(originFilePath);
                // 创建哈希对象
                const hash = crypto.createHash("md5");
                // 更新哈希值
                hash.update(fileContents);
                // 计算哈希值,并以16进编码制输出md5sum
                const md5sum = hash.digest("hex");
                // 获取文件扩展名
                const fileExtension = path.extname(originFilePath);
                // 拼接md5新的文件名
                const newFileName = `${originPath}${md5sum}${fileExtension}`;
                fs.rename(originFilePath, newFileName, (err) => {
                    if (err) throw err;
                    console.log("文件已重命名");
                    // 需要删除旧包 就加上这句逻辑。不用的话 那就不加了
                    fs.readdir(originPath, (error, files) => {
                        if (error) throw error;
                        (files || []).forEach((element) => {
                            if (element !== path.basename(newFileName)) {
                                // 删除旧zip
                                fs.unlink(
                                    path.join(originPath, element),
                                    (unlinkErr) => {
                                        if (unlinkErr) throw unlinkErr;
                                        console.log(element + "旧包已删除");
                                    },
                                );
                            }
                        });
                    });
                });
            },
        }),
    ],
});

标签:fs,const,zip,md5sum,哈希,Vite,MD5
From: https://www.cnblogs.com/tianmiaogongzuoshi/p/18416855

相关文章

  • Vite 打包之“坑”全解析(问题+解决方案)
    ......
  • vite tailwindcss@next omi
    pnpmi@tailwindcss/vite@[email protected]:{ "type":"module", "dependencies":{ "@tailwindcss/vite":"4.0.0-alpha.24", "omi":"^7.7.0", "tailwi......
  • vscode下vue3+vite+ts+eslint项目配置
    一、创建项目pnpmcreatevue@latest注意:是否引入ESLint用于代码质量检测?选择否二、安装依赖pnpmi-Deslint@antfu/eslint-config三、在项目根目录创建文件:eslint.config.js//eslint.config.jsimportantfufrom'@antfu/eslint-config'exportdefaultantfu({......
  • sipp模拟uas发送reinvite
    概述freeswitch是一款简单好用的VOIP开源软交换平台。在更新了sipp模拟update的配置方案之后,我希望对比一下fs对update和reinvite的处理流程。本文档记录sipp的配置方案,该方案中包含了update和reinvite的信令。环境CentOS7.9freeswitch1.10.7sipp.3.6.2方案描述测试......
  • vue3 + vite 使用 vite-plugin-svg-icons 插件显示本地 svg 图标的方法
    1.安装vite-plugin-svg-icons插件yarnaddvite-plugin-svg-icons-D//或者npminstallvite-plugin-svg-icons-D//或者pnpminstallvite-plugin-svg-icons-D2.使用vite-plugin-svg-icons插件2.1在项目根目录查找vite.config.js,进行配置import{createS......
  • vite如何打包vue3插件为JSSDK
    安装vitenpmcreatevite@latest你还可以通过附加的命令行选项直接指定项目名称和你想要使用的模板。例如,要构建一个Vite+Vue+ts项目,运行:#npm7+,需要添加额外的--:npmcreatevite@latestmy-vue-app----templatevue-ts查看create-vite以获取每个模板的更多细......
  • 使用VSCode搭建UniApp + TS + Vue3 + Vite项目
    uniapp是一个使用Vue.js开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、以及各种小程序。深受广大前端开发者的喜爱。uniapp官方也提供了自己的IDE工具HBuilderX,可以快速开发uniapp项目。但是很多前端的同学已经比较习惯使用VSCode去开发项目,为了开发uniapp项目......
  • Go 创建带密码的zip压缩包
    创建带密码的zip压缩包packagemainimport( "io" "log" "os" "path/filepath" "github.com/alexmullins/zip")funcinit(){ log.SetFlags(log.Lshortfile|log.LstdFlags)}funcmain(){ fzip,err:=os.Creat......
  • VUE框架基于Vite的Vue3搭建项目的脚手架------VUE框架
    data:redis:lettuce:cluster:refresh:adaptive:trueperiod:2000pool:max-idle:8min-idle:0max-wait:-1msmax-active:8password:abc123......
  • 分布式系统中的Dapper与Twitter Zipkin:链路追踪技术的实现与应用
    目录一、什么是链路追踪?二、核心思想Dapper(一)Dapper链路追踪基本概念概要(二)Trace、Span、AnnotationsTraceSpanAnnotation案例说明(三)带内数据与带外数据带外数据带内数据数据的传递与集中(四)采样采样的目的采样率的调整采样机制的实现(五)存储为什么选择BigTab......