Node4-5静态资源服务器实战以及优化压缩文件实例内容

时间:2021-05-26

浏览器控制台看一下RequestHeader有一个Accept-Encoding,而RespondHeaders中也会有一个Content-Encoding和他进行对应.

Accept-Encoding当我们的浏览器发起一个文件的请求时告诉服务器支持哪几种压缩方式,也就是服务器用这几种压缩方式浏览器都能解压,当服务器接收到请求后,知道浏览器支持的压缩方式,服务器就会自动识别其中一种进行压缩并且告诉浏览器自己用了哪个方式压缩,浏览器知道后就知道用哪种对应方式解压了

根据拓展名限制一下支持的几钟压缩类型

defaultConfig.js

压缩方法 compress,js

//压缩的方法/**rs 肯定需要,要知道自己需要压缩什么 客户端(浏览器支持哪几种压缩类型), * req 客户端再requestHeader中声明的 * res 压缩完成之后,需要告诉浏览器使用哪种压缩类型压缩,方便浏览器用对应方式进行解压 * */const { createGzip, CreateDeflate} = require('zlib')module.exports = (rs, req, res) => { const acceptEncoding = req.headers['accept-encoding']; if (!acceptEncoding || !acceptEncoding.match(/\b(gzip|deflate)/)) { return rs } else if (acceptEncoding.match(/\bgzip\b/)) { { res.setHeader('Content-Encoding', 'gzip') return rs.pipe(createGzip()) } }else if (acceptEncoding.match(/\bdeflate\b/)) { { res.setHeader('Content-Encoding', 'deflate') return rs.pipe(createGzip()) } }}

route.js 引用compress

运行结果

如果把相关压缩的代码注释掉

以上就是Node4-5静态资源服务器实战_优化压缩文件的全部知识点内容,感谢大家的阅读和对的支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章