• 缓冲区Buffer是暂时存放输入输出数据的一段内存。
  • JS语言没有二进制数据类型,而在处理TCP和文件流的时候,必须要处理二进制数据。
  • NodeJS提供了一个Buffer对象来提供对二进制数据的操作

Buffer 实例一般用于表示编码字符的序列,比如 UTF-8 、 UCS2 、 Base64 、或十六进制编码的数据。 通过使用显式的字符编码,就可以在 Buffer 实例与普通的 JavaScript 字符串之间进行相互转换。

  1. const buf = Buffer.from('runoob', 'ascii');
  2. // 输出 72756e6f6f62
  3. console.log(buf.toString('hex'));
  4. // 输出 cnVub29i
  5. console.log(buf.toString('base64'));

可以把 Buffer 看成 字节 组成的数组,每个字节用十六进制表示(取值范围:0-0xff)

定义buffer

在 v6.0 之前创建 Buffer 对象直接使用 new Buffer() 构造函数来创建对象实例,但是 Buffer 对内存的权限操作相比很大,可以直接捕获一些敏感信息,所以在 v6.0 以后,官方文档里面建议使用 Buffer.from() 接口去创建Buffer对象。

通过长度定义buffer

  1. // 创建一个长度为 10、且用 0 填充的 Buffer。
  2. const buf1 = Buffer.alloc(10);
  3. // 创建一个长度为 10、且用 0x1 填充的 Buffer。
  4. const buf2 = Buffer.alloc(10, 1);
  5. // 创建一个长度为 10、且未初始化的 Buffer。
  6. const buf3 = Buffer.allocUnsafe(10);

通过数组定义buffer

  1. // 创建一个包含 [0x1, 0x2, 0x3] 的 Buffer。
  2. const buf4 = Buffer.from([1, 2, 3]);

字符串创建

  1. //字符串创建
  2. const buf5 = Buffer.from('哈哈'); //<Buffer e5 93 88 e5 93 88>

API

Buffer 提供了以下 API 来创建 Buffer 类:

  • Buffer.alloc(size[, fill[, encoding]]): 返回一个指定大小的 Buffer 实例,如果没有设置 fill,则默认填满 0
  • Buffer.allocUnsafe(size): 返回一个指定大小的 Buffer 实例,但是它不会被初始化,所以它可能包含敏感的数据
  • Buffer.allocUnsafeSlow(size)
  • Buffer.from(array): 返回一个被 array 的值初始化的新的 Buffer 实例(传入的 array 的元素只能是数字,不然就会自动被 0 覆盖)
  • Buffer.from(arrayBuffer[, byteOffset[, length]]): 返回一个新建的与给定的 ArrayBuffer 共享同一内存的 Buffer。
  • Buffer.from(buffer): 复制传入的 Buffer 实例的数据,并返回一个新的 Buffer 实例
  • Buffer.from(string[, encoding]): 返回一个被 string 的值初始化的新的 Buffer 实例

buffer常用方法

  • fill
  • write
  • writeInt8
  • Little-Endian&Big-Endian
  • toString
  • slice
  • copy
  • concat()
  • isBuffer() 判断是否是buffer
  • length 获取字节长度