【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 中使用不同的库来压缩文件。可以根据具体需求选择合适的库和压缩格式。

相关推荐
西洼工作室2 分钟前
UniApp开发全攻略:从生命周期到路由传值
前端·javascript·uni-app
星恒随风10 分钟前
四天学完前端基础三件套(JavaScript webAPI篇)
开发语言·前端·javascript
知彼解己17 分钟前
从后端视角学习 Vue3:核心知识与数据流实践
javascript·vue.js·ecmascript
晓得迷路了32 分钟前
栗子前端技术周刊第 129 期 - TanStack npm 供应链入侵事件、pnpm 11.1、Tailwind CSS 4.3...
前端·javascript·css
ZC跨境爬虫34 分钟前
跟着 MDN 学 HTML day_59:HTML表单与按钮——构建用户交互的基石
前端·javascript·ui·html·交互·媒体
天天开发35 分钟前
Flutter Widget Previewer使用指南:提升开发效率的利器
前端·javascript·flutter
ZC跨境爬虫40 分钟前
模块化烹饪小程序开发日记 Day2:全局配置与 tabBar 实现
java·前端·javascript·微信小程序·html·notepad++
在繁华处43 分钟前
从零搭建轻灵:一个 TypeScript CLI Agent 框架的诞生
前端·javascript·typescript
ZC跨境爬虫1 小时前
模块化烹饪小程序开发日记 Day1:项目初始化与模块化目录设计
前端·javascript·ui·微信小程序·音视频
薛定猫AI3 小时前
【深度解析】从 Antigravity 更新看 Agent IDE 的工程化演进:权限、沙盒、MCP 与模型治理
前端·javascript·ide