node.js使用zlib模块进行数据压缩和解压操作示例


Posted in Javascript onFebruary 12, 2020

本文实例讲述了node.js使用zlib模块进行数据压缩和解压操作。分享给大家供大家参考,具体如下:

我们可以使用 zlib 模块来对数据进行压缩和解压处理,减小数据体积,加快传输速度。

一、通过创建转换流,对文件进行压缩和解压

const fs = require('fs');
const zlib = require('zlib');
const path = require('path');
function gzip($src) {
  fs.stat($src, function (err, stats) {
    if (stats.isFile()) {
      let rs = fs.createReadStream($src);
      //zlib.createGzip()创建一个gzip转换流,是一个可读可写流。
      //通过管道将数据读取出来写入gzip流,然后又通过管道写入一个文件流中
      $dst = path.join(__dirname, path.basename($src) + '.gz');
      rs.pipe(zlib.createGzip()).pipe(fs.createWriteStream($dst));
    }
  });
}
function ungzip($src) {
  fs.stat($src, function (err, stats) {
    if (stats.isFile()) {
      let rs = fs.createReadStream($src);
      //zlib.createGunzip()创建一个gunzip转换流
      $dst = path.join(__dirname, path.basename($src, '.gz'));
      rs.pipe(zlib.createGunzip()).pipe(fs.createWriteStream($dst));
    }
  });
}
//压缩文件
gzip('./1.txt');
//解压文件
ungzip('./1.txt.gz');

zlib.createDeflate() 和 zlib.createInflate() 的使用方法与上面类似,这里就不作演示了。

二、调用 zlib 方法对数据进行压缩与解压

const zlib = require('zlib');
let data = 'hello,world';
//参数一表示要压缩的数据,可以是string或buffer
zlib.gzip(data, function (err, buffer) {
  if (err) {
    console.log(err);
  }
  //buffer就是压缩后的数据
  console.log(buffer.toString());
  //对buffer数据进行解压
  zlib.unzip(buffer, function (err, buffer) {
    console.log(buffer.toString());
  });
});

希望本文所述对大家node.js程序设计有所帮助。

Javascript 相关文章推荐
js 异步处理进度条
Apr 01 Javascript
JavaScript加强之自定义callback示例
Sep 21 Javascript
jQuery1.9.1针对checkbox的调整方法(prop)
May 01 Javascript
学习AngularJs:Directive指令用法(完整版)
Apr 26 Javascript
javascript 中关于array的常用方法详解
May 05 Javascript
Validform验证时可以为空否则按照指定格式验证
Oct 20 Javascript
vue-cli配置文件——config篇
Jan 04 Javascript
使用koa2创建web项目的方法步骤
Mar 12 Javascript
PHP 502bad gateway原因及解决方案
Nov 13 Javascript
关于angular 8.1使用过程中的一些记录
Nov 25 Javascript
JS如何使用剪贴板操作Clipboard API
May 17 Javascript
Element实现动态表格的示例代码
Aug 02 Javascript
浅析vue-router实现原理及两种模式
Feb 11 #Javascript
vue-socket.io跨域问题有效解决方法
Feb 11 #Javascript
Vue开发中遇到的跨域问题及解决方法
Feb 11 #Javascript
Vue data的数据响应式到底是如何实现的
Feb 11 #Javascript
JS实现TITLE悬停长久显示效果完整示例
Feb 11 #Javascript
vue.config.js中配置Vue的路径别名的方法
Feb 11 #Javascript
vue-resourc发起异步请求的方法
Feb 11 #Javascript
You might like
全国FM电台频率大全 - 22 重庆市
2020/03/11 无线电
cmd下运行php脚本
2008/11/25 PHP
PHP 获取MySQL数据库里所有表的实现代码
2011/07/13 PHP
在PHP中使用redis
2013/11/04 PHP
PHP生成随机密码类分享
2014/06/25 PHP
php验证手机号码
2015/11/11 PHP
让getElementsByName适应IE和firefox的方法
2007/09/24 Javascript
js 金额文本框实现代码
2012/02/14 Javascript
table insertRow、deleteRow定义和用法总结
2014/05/14 Javascript
JavaScript中神奇的call()方法
2015/03/12 Javascript
javascript函数自动执行常用方法汇总
2016/03/28 Javascript
Bootstrap BootstrapDialog使用详解
2017/02/17 Javascript
深入浅析Vue全局组件与局部组件的区别
2018/06/15 Javascript
在Create React App中使用CSS Modules的方法示例
2019/01/15 Javascript
使用node搭建自动发图文微博机器人的方法
2019/03/22 Javascript
js变量值传到php过程详解 将php解析成数据
2019/06/26 Javascript
js实现简单音乐播放器
2020/06/30 Javascript
详解JavaScript 的执行机制
2020/09/18 Javascript
微信小程序picker组件两列关联使用方式
2020/10/27 Javascript
CentOS 8.2服务器上安装最新版Node.js的方法
2020/12/16 Javascript
[04:15]DOTA2-DPC中国联赛 正赛 Ehome vs Aster 选手采访
2021/03/11 DOTA
Python中asyncore的用法实例
2014/09/29 Python
Python3里的super()和__class__使用介绍
2015/04/23 Python
python模拟enum枚举类型的方法小结
2015/04/30 Python
常见python正则用法的简单实例
2016/06/21 Python
Python使用自带的ConfigParser模块读写ini配置文件
2016/06/26 Python
Python内置模块turtle绘图详解
2017/12/09 Python
Python实现重建二叉树的三种方法详解
2018/06/23 Python
python实现对输入的密文加密
2019/03/20 Python
Django异步任务之Celery的基本使用
2019/03/23 Python
python写入数据到csv或xlsx文件的3种方法
2019/08/23 Python
带你彻底搞懂python操作mysql数据库(cursor游标讲解)
2020/01/06 Python
css3实现平移效果(transfrom:translate)的示例
2020/11/13 HTML / CSS
原料仓仓管员岗位职责
2014/07/08 职场文书
节水宣传标语口号
2015/12/26 职场文书
Win11如何设置右键单击显示所有选项?Win11右键单击显示所有选项设置教程
2022/04/08 数码科技