node.js-archiver实现压缩文件

前言

archiver是一个用于生成存档的npm包,拥有丰富的API接口
平常使用webpack打包项目时,需要手动将打包后的文件添加为zip压缩文件,如果使用archiver就可以在打包时直接压缩为zip文件,提高打包效率。

安装

yarn init -y
yarn add archiver -D

操作

目录结构

.
├── file1.txt
├── index.js
├── package.json
└── yarn.lock

file1.txt

this is file1

压缩文件

const fs = require('fs')
const archiver = require('archiver')

// 创建文件输出流
let output = fs.createWriteStream(__dirname + '/dist.zip')
let archive = archiver('zip', {
  zlib: { level: 9 } // 设置压缩级别
})

// 文件输出流结束
output.on('close', function() {
  console.log(`总共 ${archive.pointer()} 字节`)
  console.log('archiver完成文件的归档,文件输出流描述符已关闭')
})

// 数据源是否耗尽
output.on('end', function() {
  console.log('数据源已耗尽')
})

// 存档警告
archive.on('warning', function(err) {
  if (err.code === 'ENOENT') {
    console.warn('stat故障和其他非阻塞错误')
  } else {
    throw err
  }
})

// 存档出错
archive.on('error', function(err) {
  throw err
})

// 通过管道方法将输出流存档到文件
archive.pipe(output)

// 从流中追加文件
let file1 = __dirname + '/file1.txt'
archive.append(fs.createReadStream(file1), { name: 'file1.txt' })

// 从字符串追加文件
archive.append('string cheese!', { name: 'file2.txt' })

// 从缓冲区追加文件
let buffer3 = Buffer.from('buff it!')
archive.append(buffer3, { name: 'file3.txt' })

// 追加一个文件
archive.file('file1.txt', { name: 'file4.txt' })

//完成归档
archive.finalize()

执行node index.js
生成dist.zip压缩文件
这里写图片描述
解压后内容如下
这里写图片描述

压缩文件和目录

目录结构

├── index.html
├── index.js
├── package.json
├── static
│   ├── css
│   │   └── index.css
│   ├── img
│   │   └── 1.jpg
│   └── js
│       └── index.js
└── yarn.lock
let fs = require('fs')
let archiver = require('archiver')

// 创建文件输出流
let output = fs.createWriteStream(__dirname + '/dist.zip')
let archive = archiver('zip', {
  zlib: { level: 9 } // 设置压缩级别
})

// 文件输出流结束
output.on('close', function() {
  console.log(`总共 ${archive.pointer()} 字节`)
  console.log('archiver完成文件的归档,文件输出流描述符已关闭')
})

// 数据源是否耗尽
output.on('end', function() {
  console.log('数据源已耗尽')
})

// 存档警告
archive.on('warning', function(err) {
  if (err.code === 'ENOENT') {
    console.warn('stat故障和其他非阻塞错误')
  } else {
    throw err
  }
})

// 存档出错
archive.on('error', function(err) {
  throw err
})

// 通过管道方法将输出流存档到文件
archive.pipe(output)

// 从流中附加文件
let index = __dirname + '/index.html'
archive.append(fs.createReadStream(index), { name: 'index.html' })

// 从子目录追加文件并将其命名为“新子dir”在存档中
archive.directory('static/', 'static')

// 完成归档
archive.finalize()

生成的dist.zip文件,解压后如下

├── dist
│   ├── index.html
│   └── static
│       ├── css
│       │   └── index.css
│       ├── img
│       │   └── 1.jpg
│       └── js
│           └── index.js

参考

https://github.com/archiverjs/node-archiver

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Node.js Archiver是一个Node.js库,它允许您使用易于使用的API来创建和操作归档文件(如ZIP文件,TAR文件等)。它提供了许多功能,包括添加文件,目录,删除文件,重命名文件,以及添加注释等。 使用Archiver,您可以轻松地创建归档文件,将文件和目录添加到归档文件中,以及将它们压缩和解压缩。它还提供了一些方便的功能,例如处理错误和异常,以及创建具有各种格式的归档文件。 以下是一个简单的示例,演示如何使用Archiver创建一个ZIP归档文件并将文件添加到其中: ```javascript const archiver = require('archiver'); const fs = require('fs'); const output = fs.createWriteStream('./example.zip'); const archive = archiver('zip', { zlib: { level: 9 } // 配置压缩级别 }); // 将Archive的事件附加到stream output.on('close', () => { // 这里可以做一些清理工作,或者在其他地方打开压缩文件进行进一步操作 }); // 将Archive的错误事件附加到stream archive.on('error', (err) => { throw err; }); // 执行archive操作 archive.pipe(output); // 添加文件到archive archive.file('example.txt', { name: 'example.txt' }); archive.file('anotherFile.txt', { name: 'anotherFile.txt' }); archive.file('nested/path/to/file.txt', { name: 'nested/path/to/file.txt' }); archive.finalize(); // 结束归档操作 ``` 上述代码创建了一个名为`example.zip`的归档文件,并将三个文本文件添加到其中。每个文件都有一个不同的名称,以便在归档文件中区分它们。您可以根据需要使用Archiver的其他功能和方法来创建和操作不同类型的归档文件。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值