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

相关推荐
码觉客几秒前
介绍一下基于 PDF.js 较新版本(接近或涵盖 v5.0 概念,虽然实际稳定版本可能是 v4.x)获取批注列表的方法
前端·javascript
顾洋洋几秒前
WASM与OPFS组合技系列二(魔改读操作)
前端·javascript·webassembly
@PHARAOH17 分钟前
WHAT - React 两个重要的 Typescript 类型:ReactNode vs JSX.Element
javascript·react.js·typescript
PyAIGCMaster18 分钟前
react从零开始的基础课
开发语言·javascript·ecmascript
Gazer_S19 分钟前
【CornerTag组件详解:优雅的角标设计与实现】
前端·javascript·vue.js
祈澈菇凉21 分钟前
什么是 React Router?如何使用?
javascript·react.js·ecmascript
插件开发43 分钟前
JavaScript-异步和同步函数使用场景及区别-正确构建程序的核心要点
开发语言·javascript·ecmascript
叶浩成5201 小时前
arco-design-vue:给<a-table>组件每一行添加data-id属性,并根据id数组是否包含此行id进行样式处理
前端·javascript·vue.js
我自纵横20231 小时前
Vue 3 中 ref 与 reactive 的对比
前端·javascript·vue.js·typescript·前端框架·html5
在掘金2 小时前
【kk-utils】树结构工具——tree
前端·javascript