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

相关推荐
软件聚导航1 小时前
对uniApp 组件 picker-view 的二次封装,实现日期,时间、自定义数据滚动选择,容易扩展
前端·javascript·html
浮游本尊1 小时前
对象、函数、原型之间的关系
开发语言·javascript·原型模式
码农丁丁1 小时前
[前端]mac安装nvm(node.js)多版本管理
前端·macos·node.js·nvm
TWenYuan2 小时前
【上传文件过大进行的切片式上传】
javascript·vue.js
HsuYang2 小时前
Rollup源码学习(七)——重识Rollup生成生命周期
前端·javascript·架构
风清云淡_A2 小时前
【原生js案例】ajax的简易封装实现后端数据交互
前端·javascript
前端郭德纲2 小时前
前端:金额高精度处理
前端·javascript
web137656076432 小时前
前端react入门day01-了解react和JSX基础
前端·javascript·react.js
我叫汪枫2 小时前
Vue2如何优雅处理多个组件渲染
前端·javascript·vue.js
天天进步20152 小时前
基于 Vue 3 实现无限滚动翻页组件
前端·javascript·vue.js