如何使用Node的内置模块zlib进行gzip压缩
导读:本文共2165字符,通常情况下阅读需要7分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要:");});这是一个简单的node服务器,浏览器访问它后,它会向我们返回一个index.html,这个index.html里的内容大家随便写,写的越多越好这里也使用到了上一节我们讲过的内置模块fs中的stream流,需要注意的是,在node服务器中的res参数本质是一个可写流,所以我们才能直接将res用于pipe管道中如果你对node搭建服务器或者内置模块fs的stream流不太了解的... ...
目录
(为您整理了一些要点),点击可以直达。");
});
这是一个简单的node
服务器,浏览器访问它后,它会向我们返回一个index.html
,这个index.html
里的内容大家随便写,写的越多越好
这里也使用到了上一节我们讲过的内置模块fs
中的stream
流,需要注意的是,在node
服务器中的res
参数本质是一个可写流,所以我们才能直接将res
用于pipe
管道中
如果你对
node
搭建服务器或者内置模块fs
的stream
流不太了解的话,可以看我先前的文章:Node.js | 搭建后端服务器(含内置模块 http | url | querystring 的使用)Node.js | 操作本地文件 — 玩转 fs 内置模块
运行server.js
文件,使用浏览器访问node
服务器:
可以看到我这里传递的数据大小是97.6kb(这取决于你的index.html
的内容)
gzip压缩数据传输
我们使用gzip
来改造一下上面普通数据传输的例子:
server.js
consthttp=require("http");
constfs=require("fs");
//导入内置模块zlib
constzlib=require("zlib");
//获取gzip方法
constgzip=zlib.createGzip();
http.createServer((req,res)=>{
res.writeHead(200,{
"Content-Type":"text/html;charset=utf-8",
"Content-Encoding":"gzip",//告诉浏览器我们是通过gzip压缩的
});constreadStream=fs.createReadStream("./index.html");
//res本质就是一个可写流
//在数据返回之前使用gzip压缩数据
readStream.pipe(gzip).pipe(res);
}).listen(3000,()=>{
console.log("服务器启动啦!");
});
先引入zlib
内置模块,再使用zlib.createGzip()
获取gzip
方法,这个gzip
方法实际也是一种数据流的格式,与node
服务器中的res
参数一样,这也是pipe
管道中能直接使用gzip
的原因
我们在将数据传递给res
参数(客户端)之前,通过pipe
管道的链式调用,将gzip
加上
这样readStream
(服务端)的数据会先经过gzip
压缩,之后才会传递给res
参数(客户端)
❗️ 需要注意的是:
http
数据压缩的方式不止有gzip
,还有其它的压缩方式,只不过gzip
是最常见最常用的一种方式
所以我们服务端使用gzip
将数据压缩后传递给浏览器时,浏览器并不知道我们是使用哪种方式压缩的数据,于是就不知道该以哪种方式进行解压,所以我们需要手动明确的告诉浏览器我们使用的是gzip
,服务端加上以下响应头即可:
"Content-Encoding":"gzip",//告诉浏览器我们是通过gzip压缩的
这样浏览器就能够正确解压我们传递的数据了,运行上面的server.js
,打开浏览器访问我们的node
服务器:
可以看到使用gzip
压缩后我这里传递的数据大小只有27.5kb(这取决于你的index.html
的内容),这与之前的97.6kb相比,数据传输速率大幅提升,这就是我们使用gzip
的意义!
如何使用Node的内置模块zlib进行gzip压缩的详细内容,希望对您有所帮助,信息来源于网络。