Node.js中如何创建和提取zip文件方法介绍

作者:神秘网友 发布时间:2020-11-26 17:00:35

Node.js中如何创建和提取zip文件方法介绍

Node.js中如何创建和提取zip文件方法介绍

相关推荐:《nodejs 教程》

Zip文件是常用的压缩文件格式。大多数开发人员最终使用tarball而不是zip文件。但在某些情况下,您需要使用zip文件,例如将函数上载到AWS Lambda。在本文中,我将演示如何用 adm-zip npm模块创建和提取zip文件。

创建一个Zip文件

从 adm-zip 的 npm 模块中导出一个 AdmZip 类。 AdmZip的实例对应于一个zip文件。如果想要创建一个新的 zip 文件,在调用 new AdmZip() 时不应带任何参数:

const AdmZip = require('adm-zip');

const file = new AdmZip();

可以通过多种方式将文件和目录添加到 file。可以用 file.addLocalFile()file.addLocalFolder() 通过文件名从文件系统添加文件和目录。例如下面的代码演示了怎样把 package.json 文件和 node_modules 目录添加到 zip 文件中:

const AdmZip = require('adm-zip');

const file = new AdmZip();

file.addLocalFile('./package.json');
//第二个node_modules 参数是 zip 中目录的路径。
//如果没有第二个参数,则`./node_modules`中的每个目录都将是压缩文件中的顶级目录
file.addLocalFolder('./node_modules', 'node_modules');

然后,你可以使用下面两种方法中的一个写入文件:

//写入zip文件的第一种方法:将其转换为缓冲区并使用`fs`
const fs = require('fs');

fs.writeFileSync('output.zip', file.toBuffer());

// 另一种写入 zip 文件的方法:writeZip()
file.writeZip('output.zip');

写入output.zip 文件后,你应该能够在制定的 zip 解压缩程序中打开它。下面是在 Xubuntu 的默认存档管理器 engrampa 中打开的文件。

Node.js中如何创建和提取zip文件方法介绍

addLocalFile()addLocalFolder() 的第二个参数是将文件或目录内容放入zip的路径。例如,如果要将 package.jsonnode_modules 都放在 project 目录下,则可以运行以下脚本:

const AdmZip = require('adm-zip');

const file = new AdmZip();

file.addLocalFile('./package.json', 'project');
file.addLocalFolder('./node_modules', 'project/node_modules');

const fs = require('fs');

fs.writeFileSync('output.zip', file.toBuffer());

可以用 file.addFile() 方法从原始 Node.js 缓冲区添加文件。以下是不在文件系统上创建文件的情况下,将包含字符串 Hello,World 的文本文件添加到 zip 文件中的方法。

const AdmZip = require('adm-zip');

const file = new AdmZip();

file.addFile('hello.txt', Buffer.fromString('Hello, World'));

const fs = require('fs');

fs.writeFileSync('output.zip', file.toBuffer());

使用现有文件

如果你将参数传递给 AdmZip 构造函数,则adm-zip将在给定路径下解析文件。下面是将所有内容从 output.zip 文件提取到目录 output 的方法。

const AdmZip = require('adm-zip');

const file = new AdmZip('./output.zip');

file.extractAllTo('./output');

也可以用 file.extractEntryTo() 从 zip 文件中提取单个文件。例如,下面是从 zip 文件中拉出 hello.txt 文件并将其写入当前目录的方法:

const AdmZip = require('adm-zip');

const file = new AdmZip('./output.zip');

file.extractEntryTo('hello.txt', './');

你也可以对现有文件使用 addLocalFile()addLocalFolder()addFile()

总结

zip 文件通常用于压缩。某些服务(例如AWS Lambda)要求你使用 zip 文件。幸运的是,adm-zip npm 模块使直接从 Node.js 创建和提取 zip 文件变得容易。

英文原文地址:http://thecodebarbarian.com/working-with-zip-files-in-node-js.html

作者:Valeri Karpov

更多编程相关知识,请访问:编程视频!!

Node.js中如何创建和提取zip文件?方法介绍的教程已介绍完毕,更多请关注跳墙网其他文章教程!

Node.js中如何创建和提取zip文件方法介绍相关教程

  1. jquery如何实现一键全选

    jquery实现一键全选的方法:首先设置选项框;然后引入jQuery,并且给按钮绑定一个jQuery类型的点击事件;最后通过prop来设置input的属性即可设置全

  2. windows下如何刷新host

    window环境下hosts文件的位置:C:\windows\system32\drivers\etc 刷新方式: 1、按win+r组合键,输入CMD,回车 2、在命令行执行如下命令 ipconfig /flushdns #清除DNS缓存内容 ps:ipconfig /displaydns //显示DNS缓存内容 linux环境下hosts文件的位置:/etc

  3. vue.js如何遍历数组

    vue.js遍历数组的方法:1、使用foreach循环,代码为【this.urls.forEach(item =】;2、使用filter循环,代码为【return this.urls.filter(item =】。 该方法适用于所有品牌电脑 vue.js遍历数组的方法: 1、 foreach foreach循环对不能使用return来停止循环 s

  4. 如何把jquery的值放入img标签的src里面

    把jquery的值放入img标签的src里面的方法:首先新建html文件,并引入jquery;然后在【index.html】中的【script】标签,输入jquery代码;最后浏览器运行【index.html】页面即可。 该方法适用于所有品牌电脑 把jquery的值放入img标签的src里面的方法: 1、首

  5. Jquery如何判断某个标签Id是否存在

    jquery判断某个标签Id是否存在的方法:使用jQuery对象的属性length来判断,如果【0】就存在,代码为【if($(#id)[0]){} else {}】。 该方法适用于所有品牌电脑 jquery判断某个标签Id是否存在的方法: 在项目中遇到需要判断某个div元素是否有id这个属性的需求

  6. jQuery如何选择以特定字符开头的ID元素

    jQuery选择以特定字符开头的ID元素的方法:使用jquery的【[attribute=value]】选择器来实现,【[attribute=value]】选择器选取每个带有指定属性且以指定字符串开头的元素。 该方法适用于所有品牌电脑 jQuery选择以特定字符开头的ID元素的方法: 想要使用jQue

  7. 如何解决jquery on 不生效问题

    jquery on不生效的解决办法:首先打开相应的代码文件;然后通过正确的方法“$(body).on(click, #test .evt, function() {alert($(this).text())});”使用on即可。 推荐:《jquery教程》 该方法适用于所有品牌电脑。 jquery的on()绑定无效的方式 on前面的元素

  8. jquery如何获取祖先元素

    jquery获取祖先元素的方法:使用方法【parent(exp)】,取得一个包含着所有匹配元素的唯一父元素的元素集合,代码为【alert($(this).parent().next().html())】。 该方法适用于所有品牌电脑 jquery获取祖先元素的方法: parent是找当前元素的第一个父节点,pa

每天更新java,php,javaScript,go,python,nodejs,vue,android,mysql等相关技术教程,教程由网友分享而来,欢迎大家分享IT技术教程到本站,帮助自己同时也帮助他人!

Copyright 2020, All Rights Reserved. Powered by 跳墙网(www.tqwba.com)|网站地图|关键词