【JS】node.js压缩文件的方式

在 Node.js 中,有多种方法可以压缩文件。以下是几种常见的压缩方式及其对应的代码示例:

  1. 使用 archiver 压缩成 ZIP 文件
  2. 使用 zlib 压缩成 GZIP 文件
  3. 使用 tar 压缩成 TAR 文件

1. 使用 archiver 压缩成 ZIP 文件

archiver 是一个功能强大的库,可以创建 ZIP、TAR 等多种格式的压缩文件。以下是一个示例:

javascript 复制代码
const fs = require('fs-extra');
const archiver = require('archiver');
const path = require('path');

async function createZip(outputPath, files) {
  // 创建一个文件输出流
  const output = fs.createWriteStream(outputPath);
  const archive = archiver('zip', {
    zlib: { level: 9 } // 设置压缩等级
  });

  // 监听所有 archive 数据写入完成
  output.on('close', function() {
    console.log(`压缩包已创建,总共 ${archive.pointer()} 字节`);
  });

  // 监听归档警告(如压缩效率低)
  archive.on('warning', function(err) {
    if (err.code === 'ENOENT') {
      console.warn('警告:', err);
    } else {
      throw err;
    }
  });

  // 监听归档出错
  archive.on('error', function(err) {
    throw err;
  });

  // 将输出流与 archive 管道连接
  archive.pipe(output);

  // 添加文件到压缩包
  for (const file of files) {
    const filePath = path.resolve(file);
    archive.file(filePath, { name: path.basename(filePath) });
  }

  // 完成归档
  await archive.finalize();
}

// 使用示例
const outputPath = 'output.zip';
const files = ['file1.txt', 'file2.txt', 'file3.txt'];

createZip(outputPath, files)
  .then(() => console.log('压缩包创建成功'))
  .catch(err => console.error('创建压缩包时出错:', err));

2. 使用 zlib 压缩成 GZIP 文件

zlib 是 Node.js 内置的压缩库,支持 GZIP 和 Deflate。以下是一个示例:

javascript 复制代码
const fs = require('fs');
const zlib = require('zlib');

function createGzip(inputFile, outputFile) {
  const gzip = zlib.createGzip();
  const input = fs.createReadStream(inputFile);
  const output = fs.createWriteStream(outputFile);

  // 将输入流通过 gzip 压缩后写入输出流
  input.pipe(gzip).pipe(output);

  output.on('finish', function() {
    console.log(`文件已压缩成 ${outputFile}`);
  });
}

// 使用示例
const inputFile = 'file.txt';
const outputFile = 'file.txt.gz';

createGzip(inputFile, outputFile);

3. 使用 tar 压缩成 TAR 文件

tar 是一个用于创建 TAR 文件的库。以下是一个示例:

javascript 复制代码
const tar = require('tar');
const fs = require('fs');

async function createTar(outputPath, files) {
  await tar.c(
    {
      gzip: true, // 是否使用 gzip 压缩
      file: outputPath // 输出文件路径
    },
    files // 要压缩的文件列表
  );

  console.log(`文件已压缩成 ${outputPath}`);
}

// 使用示例
const outputPath = 'output.tar.gz';
const files = ['file1.txt', 'file2.txt', 'file3.txt'];

createTar(outputPath, files)
  .then(() => console.log('压缩包创建成功'))
  .catch(err => console.error('创建压缩包时出错:', err));

这些示例展示了如何在 Node.js 中使用不同的库来压缩文件。可以根据具体需求选择合适的库和压缩格式。

相关推荐
2501_920931701 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
AI老李1 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
方也_arkling2 小时前
Element Plus主题色定制
javascript·sass
2601_949809592 小时前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter
Up九五小庞2 小时前
开源埋点分析平台 ClkLog 本地部署 + Web JS 埋点测试实战--九五小庞
前端·javascript·开源
摘星编程3 小时前
React Native + OpenHarmony:UniversalLink通用链接
javascript·react native·react.js
qq_177767373 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头88213 小时前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
程序员清洒5 小时前
Flutter for OpenHarmony:Text — 文本显示与样式控制
开发语言·javascript·flutter
雨季6665 小时前
Flutter 三端应用实战:OpenHarmony 简易“动态内边距调节器”交互模式深度解析
javascript·flutter·ui·交互·dart