- assert断言
- async_hooks异步钩子
- async_hooks/context异步上下文
- buffer缓冲区
- C++插件
- C/C++插件(使用Node-API)
- C++嵌入器
- child_process子进程
- cluster集群
- CLI命令行
- console控制台
- Corepack核心包
- crypto加密
- crypto/webcrypto网络加密
- debugger调试器
- deprecation弃用
- dgram数据报
- diagnostics_channel诊断通道
- dns域名服务器
- domain域
- Error错误
- events事件触发器
- fs文件系统
- global全局变量
- http超文本传输协议
- http2超文本传输协议2.0
- https安全超文本传输协议
- inspector检查器
- Intl国际化
- module模块
- module/cjsCommonJS模块
- module/esmECMAScript模块
- module/package包模块
- net网络
- os操作系统
- path路径
- perf_hooks性能钩子
- policy安全策略
- process进程
- punycode域名代码
- querystring查询字符串
- readline逐行读取
- repl交互式解释器
- report诊断报告
- stream流
- stream/web网络流
- string_decoder字符串解码器
- timers定时器
- tls安全传输层
- trace_events跟踪事件
- tty终端
- url网址
- util实用工具
- v8引擎
- vm虚拟机
- wasi网络汇编系统接口
- worker_threads工作线程
- zlib压缩
Node.js v16.16.0 文档
- Node.js 16.16.0
-
►
目录
- zlib 压缩
- 线程池的使用与性能的考虑
- 压缩 HTTP 的请求和响应
- 内存使用的调整
- 刷新
- 常量
Options
类BrotliOptions
类zlib.BrotliCompress
类zlib.BrotliDecompress
类zlib.Deflate
类zlib.DeflateRaw
类zlib.Gunzip
类zlib.Gzip
类zlib.Inflate
类zlib.InflateRaw
类zlib.Unzip
类zlib.ZlibBase
类zlib.constants
zlib.createBrotliCompress([options])
zlib.createBrotliDecompress([options])
zlib.createDeflate([options])
zlib.createDeflateRaw([options])
zlib.createGunzip([options])
zlib.createGzip([options])
zlib.createInflate([options])
zlib.createInflateRaw([options])
zlib.createUnzip([options])
- 便捷方法
zlib.brotliCompress(buffer[, options], callback)
zlib.brotliCompressSync(buffer[, options])
zlib.brotliDecompress(buffer[, options], callback)
zlib.brotliDecompressSync(buffer[, options])
zlib.deflate(buffer[, options], callback)
zlib.deflateSync(buffer[, options])
zlib.deflateRaw(buffer[, options], callback)
zlib.deflateRawSync(buffer[, options])
zlib.gunzip(buffer[, options], callback)
zlib.gunzipSync(buffer[, options])
zlib.gzip(buffer[, options], callback)
zlib.gzipSync(buffer[, options])
zlib.inflate(buffer[, options], callback)
zlib.inflateSync(buffer[, options])
zlib.inflateRaw(buffer[, options], callback)
zlib.inflateRawSync(buffer[, options])
zlib.unzip(buffer[, options], callback)
zlib.unzipSync(buffer[, options])
- zlib 压缩
-
►
索引
- assert 断言
- async_hooks 异步钩子
- async_hooks/context 异步上下文
- buffer 缓冲区
- C++插件
- C/C++插件(使用Node-API)
- C++嵌入器
- child_process 子进程
- cluster 集群
- CLI 命令行
- console 控制台
- Corepack 核心包
- crypto 加密
- crypto/webcrypto 网络加密
- debugger 调试器
- deprecation 弃用
- dgram 数据报
- diagnostics_channel 诊断通道
- dns 域名服务器
- domain 域
- Error 错误
- events 事件触发器
- fs 文件系统
- global 全局变量
- http 超文本传输协议
- http2 超文本传输协议2.0
- https 安全超文本传输协议
- inspector 检查器
- Intl 国际化
- module 模块
- module/cjs CommonJS模块
- module/esm ECMAScript模块
- module/package 包模块
- net 网络
- os 操作系统
- path 路径
- perf_hooks 性能钩子
- policy 安全策略
- process 进程
- punycode 域名代码
- querystring 查询字符串
- readline 逐行读取
- repl 交互式解释器
- report 诊断报告
- stream 流
- stream/web 网络流
- string_decoder 字符串解码器
- timers 定时器
- tls 安全传输层
- trace_events 跟踪事件
- tty 终端
- url 网址
- util 实用工具
- v8 引擎
- vm 虚拟机
- wasi 网络汇编系统接口
- worker_threads 工作线程
- zlib 压缩
- ► 其他版本
- 文档搜索
- 会员登录
目录
- zlib 压缩
- 线程池的使用与性能的考虑
- 压缩 HTTP 的请求和响应
- 内存使用的调整
- 刷新
- 常量
Options
类BrotliOptions
类zlib.BrotliCompress
类zlib.BrotliDecompress
类zlib.Deflate
类zlib.DeflateRaw
类zlib.Gunzip
类zlib.Gzip
类zlib.Inflate
类zlib.InflateRaw
类zlib.Unzip
类zlib.ZlibBase
类zlib.constants
zlib.createBrotliCompress([options])
zlib.createBrotliDecompress([options])
zlib.createDeflate([options])
zlib.createDeflateRaw([options])
zlib.createGunzip([options])
zlib.createGzip([options])
zlib.createInflate([options])
zlib.createInflateRaw([options])
zlib.createUnzip([options])
- 便捷方法
zlib.brotliCompress(buffer[, options], callback)
zlib.brotliCompressSync(buffer[, options])
zlib.brotliDecompress(buffer[, options], callback)
zlib.brotliDecompressSync(buffer[, options])
zlib.deflate(buffer[, options], callback)
zlib.deflateSync(buffer[, options])
zlib.deflateRaw(buffer[, options], callback)
zlib.deflateRawSync(buffer[, options])
zlib.gunzip(buffer[, options], callback)
zlib.gunzipSync(buffer[, options])
zlib.gzip(buffer[, options], callback)
zlib.gzipSync(buffer[, options])
zlib.inflate(buffer[, options], callback)
zlib.inflateSync(buffer[, options])
zlib.inflateRaw(buffer[, options], callback)
zlib.inflateRawSync(buffer[, options])
zlib.unzip(buffer[, options], callback)
zlib.unzipSync(buffer[, options])
zlib 压缩#
zlib
模块提供了使用 Gzip、Deflate/Inflate、以及 Brotli 实现的压缩功能。
线程池的使用与性能的考虑#
所有 zlib
API,除了那些显式同步的 API,都使用 Node.js 内部线程池。
这可能会在某些应用程序中导致令人惊讶的效果和性能限制。
压缩 HTTP 的请求和响应#
zlib
模块可用于实现对 HTTP 定义的 gzip
、deflate
和 br
内容编码机制的支持。
内存使用的调整#
对于基于 zlib 的流#
从 zlib/zconf.h
开始,针对 Node.js 使用进行了修改:
对于基于 Brotli 的流#
有与基于 Brotli 的流的 zlib 选项等效的选项,尽管这些选项的范围与 zlib 的范围不同:
刷新#
在压缩流上调用 .flush()
将使 zlib
返回尽可能多的当前输出。
这可能以降低压缩质量为代价,但在需要尽快提供数据时非常有用。
常量#
zlib 常量#
zlib.h
中定义的所有常量也在 require('zlib').constants
上定义。
在正常的操作过程中,没有必要使用这些常量。
它们被记录在案,因此它们的存在不足为奇。
本章节几乎直接取自 zlib 文档。
Brotli 常量#
有几个选项和其他常量可用于基于 Brotli 的流:
刷新操作#
以下值是基于 Brotli 的流的有效刷新操作:
压缩器选项#
可以在 Brotli 编码器上设置几个选项,影响压缩效率和速度。
键和值都可以作为 zlib.constants
对象的属性访问。
解压器选项#
这些高级选项可用于控制减压:
Options
类#
每个基于 zlib 的类都有一个 options
对象。
不需要任何选项。
BrotliOptions
类#
每个基于 Brotli 的类都有一个 options
对象。
所有选项都是可选的。
zlib.BrotliCompress
类#
使用 Brotli 算法压缩数据。
zlib.BrotliDecompress
类#
使用 Brotli 算法解压缩数据。
zlib.Deflate
类#
使用 deflate 压缩数据。
zlib.DeflateRaw
类#
使用 deflate 压缩数据,并且不附加 zlib
标头。
zlib.Gunzip
类#
解压缩 gzip 流。
zlib.Gzip
类#
使用 gzip 压缩数据。
zlib.Inflate
类#
解压缩 deflate 流。
zlib.InflateRaw
类#
解压缩原始的 deflate 流。
zlib.Unzip
类#
通过自动检测标头来解压缩 Gzip 或 Deflate 压缩的流。
zlib.ZlibBase
类#
不是由 zlib
模块导出的。
它记录在此处,因为它是压缩器/解压缩器类的基类。
zlib.bytesRead
#
弃用的 zlib.bytesWritten
别名。
选择这个原始名称是因为将值解释为引擎读取的字节数也是有意义的,但与 Node.js 中以这些名称公开值的其他流不一致。
zlib.bytesWritten
#
zlib.bytesWritten
属性指定在处理字节(压缩或解压缩,视派生类而定)之前写入引擎的字节数。
zlib.close([callback])
#
关闭底层句柄。
zlib.flush([kind, ]callback)
#
刷新挂起的数据。 不要轻率地称之为,过早刷新会对压缩算法的有效性产生负面影响。
zlib.params(level, strategy, callback)
#
此函数仅适用于基于 zlib 的流,即不适用于 Brotli。
zlib.reset()
#
将压缩器/解压缩器重置为出厂默认设置。 仅适用于 inflate 和 deflate 算法。
zlib.constants
#
提供枚举 Zlib 相关常量的对象。
zlib.createBrotliCompress([options])
#
创建并返回新的 BrotliCompress
对象。
zlib.createBrotliDecompress([options])
#
创建并返回新的 BrotliDecompress
对象。
zlib.createDeflate([options])
#
创建并返回新的 Deflate
对象。
zlib.createDeflateRaw([options])
#
创建并返回新的 DeflateRaw
对象。
zlib.createGunzip([options])
#
创建并返回新的 Gunzip
对象。
zlib.createGzip([options])
#
zlib.createInflate([options])
#
创建并返回新的 Inflate
对象。
zlib.createInflateRaw([options])
#
创建并返回新的 InflateRaw
对象。
zlib.createUnzip([options])
#
创建并返回新的 Unzip
对象。
便捷方法#
所有这些都将 Buffer
、TypedArray
、DataView
、ArrayBuffer
或字符串作为第一个参数,可选的第二个参数为 zlib
类提供选项,并将使用 callback(error, result)
调用提供的回调。
zlib.brotliCompress(buffer[, options], callback)
#
buffer
<Buffer> | <TypedArray> | <DataView> | <ArrayBuffer> | <string>options
<brotli options>callback
<Function>
zlib.brotliCompressSync(buffer[, options])
#
使用 BrotliCompress
压缩数据块。
zlib.brotliDecompress(buffer[, options], callback)
#
buffer
<Buffer> | <TypedArray> | <DataView> | <ArrayBuffer> | <string>options
<brotli options>callback
<Function>
zlib.brotliDecompressSync(buffer[, options])
#
使用 BrotliDecompress
解压缩数据块。
zlib.deflate(buffer[, options], callback)
#
zlib.deflateSync(buffer[, options])
#
使用 Deflate
压缩数据块。
zlib.deflateRaw(buffer[, options], callback)
#
zlib.deflateRawSync(buffer[, options])
#
使用 DeflateRaw
压缩数据块。
zlib.gunzip(buffer[, options], callback)
#
zlib.gunzipSync(buffer[, options])
#
使用 Gunzip
解压缩数据块。
zlib.gzip(buffer[, options], callback)
#
zlib.gzipSync(buffer[, options])
#
使用 Gzip
压缩数据块。
zlib.inflate(buffer[, options], callback)
#
zlib.inflateSync(buffer[, options])
#
使用 Inflate
解压缩数据块。
zlib.inflateRaw(buffer[, options], callback)
#
zlib.inflateRawSync(buffer[, options])
#
使用 InflateRaw
解压缩数据块。
zlib.unzip(buffer[, options], callback)
#
zlib.unzipSync(buffer[, options])
#
使用 Unzip
解压缩数据块。