Buffer和二进制
对于前端开发来说,通常很少会和二进制打交道,但是对于服务器端为了做很多的功能,我们必须直接去操作其二进制的数据;所以Node为了可以方便开发者完成更多功能,提供给了我们一个类Buffer,并且它是全局的。
1.Buffer中存储的是二进制数据,那么到底是如何存储呢?
- 我们可以将Buffer看成是一个存储二进制的数组
- 这个数组中的每一项,可以保存8位二进制: 00000000
2.为什么是8位呢
- 在计算机中,很少的情况我们会直接操作一位二进制,因为一位二进制存储的数据是非常有限的;
- 所以通常会将8位合在一起作为一个单元,这个单元称之为一个字节(byte);
- 也就是说 1byte = 8bit,1kb=1024byte,1M=1024kb;
- 比如RGB的值分别都是255,所以本质上在计算机中都是用一个字节存储的;
Buffer和字符串
- Buffer相当于是一个字节的数组,数组中的每一项对于一个字节的大小:
- 如果我们希望将一个字符串放入到Buffer中,是怎么样的过程呢
const message = 'Hello world'
// 1.创建方式一
// const buffer = new Buffer(message)
// console.log(buffer)
// 2.创建方式二
const buffer = Buffer.from(message)
console.log(buffer);
将字符串转成对应的ascall码的16进制,Buffer中存储的是其对应的16进制。
中文如何解析
- 默认编码:utf-8
- 可以改成utf16
const message = '你好啊'
// const buffer = Buffer.from(message,'utf8')
const buffer = Buffer.from(message, 'utf16le')
console.log(buffer)
console.log(buffer.toString('utf16le'))
编码解码需要保持同一种格式
解码可以使用toString()
Buffer的其它创建方式
1.使用 Buffer.alloc() 方法创建指定大小的 Buffer,该方法会将 Buffer 中的所有字节都设置为 0。例如:
const buffer = Buffer.alloc(8)
console.log(buffer)
buffer[0] = 0x88
console.log(buffer)
2.使用 Buffer.allocUnsafe() 方法创建指定大小的 Buffer,该方法不会清空 Buffer 中的数据,因此创建的 Buffer 可能包含敏感信息。如果需要清空 Buffer 中的数据,可以使用 Buffer.fill() 方法。例如:
const buf = Buffer.allocUnsafe(10);
buf.fill(0);
console.log(buf)
这个例子中,创建了一个大小为 10 字节的未初始化的 Buffer 对象,然后使用 fill() 方法将所有字节都设置为 0。
Buffer和文件读取
sharp:图片的处理,包括裁剪。 https://blog.lcddjm.com/sharp-documents-cn/文章来源:https://www.toymoban.com/news/detail-496450.html
npm i sharp文章来源地址https://www.toymoban.com/news/detail-496450.html
const fs = require('fs')
const sharp = require('sharp')
// 读文本文件
// fs.readFile('./foo.txt', (err, data) => {
// console.log(data)
// console.log(data.toString())
// })
// 读图片
// fs.readFile('./bar.png', (err, data) => {
// console.log(data)
// // 复制文件
// fs.writeFile('./copybar.png', data, (err, data) => {
// console.log(err)
// })
// })
// sharp的使用
sharp('./bar.png')
.resize(300, 300)
.toBuffer()
.then(data => {
fs.writeFile('./bax.png', data, err => console.log(err))
})
到了这里,关于04-Buffer的使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!