一、 Archiver
1、 安装
npm install archiver
2、 使用
由于需要做文件操作,所以我们需要将fs库也引进来
先创建一个可写流,用于传入压缩包数据
再创建一个archiver实例,其实就是一个可读流。指定压缩格式与压缩等级:压缩格式支持zip与tar;压缩等级的话,速度最快的是1,也就是不压缩,压缩包大小与包内文件大小总和几乎相等,而压缩性能最好的是9。
使用pipe将两个流连接,开始写压缩包数据
单个文件压缩的话,可以使用append来逐个添加。append方法的第一个参数是source,传入的可以是string、buffer或者stream,支持多种方法添加文件,下图我们添加一个通过buffer生成的文件;第二个参数是data,传入的是文件信息,这里我们只指定文件名称。
当然了,archiver也支持整个文件夹压缩,使用directory方法压缩,第一个参数是源目录路径,第二个参数是压缩目录路径,下图会将当前目录的subdir目录下所有文件压缩到压缩包中的new-subdir目录中。
如果将directory的第二个参数设置为false,则压缩包中不会新建目录。
最后使用finalize进行压缩
如果只是想生成临时压缩包,想动态生成动态删除的话,可以通过监听可写流的close事件来删除,但是注意监听应该写于调用finalize之前,如下:
返回给前端的话,可以直接返回archiver实例,因为archiver实例本质上也是一个文件流。
更多详情可以参考archiver的api文档:https://www.archiverjs.com/
二、 Compressing
1、 安装
npm install compressing
2、 使用
引进fs与compressing库
这里简单了解了下,compressing也支持直接压缩一个文件夹,语法简单明确,使用compressDir命令压缩文件夹,返回的是Promise,所以可以用await来进行同步。
更多详情可以参考compressing的文档:https://www.npmjs.com/package/compressing
三、 Linux zip命令
1、 安装
首先先确保系统中有zip包,没有的话安装一下
Centos:yum install -y zip
Ubuntu:apt-get install zip
Nodejs中我们使用child_process这个库来执行linux命令
npm install child_process
2、 使用
引入execSync,看到sync你就知道了,这个是用来同步执行命令的
使用execSync执行zip命令,这里会把tmp目录下的test文件夹压缩到tmp目录下的test.zip压缩包中
执行完压缩命令,把这个压缩文件读出来返回就好了,如下
四、 前端如何下载
前端的话,最简单的办法就是直接用标签下载,当然我们也可以直接操作DOM,动态生成一个a节点来模拟点击下载操作,这里也介绍一下:
1、 先创建一个a节点,将style设置为none,
2、 然后设置a节点的href为下载链接,设置a节点的download为下载文件名
3、 将a节点添加到DOM中
4、 调用click方法,模拟点击操作
5、 移除a节点