Nodejs의 버퍼를 JSON 형식과 UTF-8 문자열로 변환하는 방법은 무엇입니까? 다음 글에서는 Nodejs에서 버퍼와 JSON 형식을 변환하는 방법과 Buffer를 UTF-8 문자열로 변환하는 방법을 소개하겠습니다.
Node.js는 브라우저 기반 JavaScript와 다릅니다. Node는 ES6 초안에서 ArrayBuffer
를 제안하기 전에도 바이너리 데이터를 처리할 수 있는 방법이 있었기 때문입니다. Node에서 Buffer
(버퍼) 클래스는 대부분의 I/O 작업에 사용되는 기본 데이터 구조입니다. V8 힙 외부에 할당된 원시 바이너리 데이터이며 할당되면 크기를 조정할 수 없습니다. [추천 학습: Node v6의 "nodejs tutorialArrayBuffer
之前就有处理二进制数据的方法。在 Node 中,Buffer
(缓冲区) 类是大多数 I/O 操作使用的主要数据结构。它是在 V8 堆外部分配的原始二进制数据,一旦分配,就无法调整大小。【推荐学习:《nodejs 教程》】
在 Node v6.0 之前,要创建新的缓冲区,我们只需使用 new
关键字调用构造函数:
let newBuff = new Buffer('I Love You')
v6.0 之后,要创建新的缓冲区实例:
let newBuff = Buffer.from('I Love You')
new Buffer()
构造函数已被弃用,并被单独的 Buffer.from()
、Buffer.alloc()
和 Buffer.allocUnsafe()
方法替换。
更多信息可以阅读官方文档。
缓冲区可以转换为 JSON。
let bufferOne = Buffer.from('All work and no play makes Jack a dull boy') console.log(bufferOne) // <Buffer 41 6c 6c 20 77 6f 72 6b 20 61 6e 64 20 6e 6f 20 70 6c 61 79 20 6d 61 6b 65 73 20 4a 61 63 6b 20 61 20 64 75 6c 6c 20 62 6f 79> let json = JSON.stringify(bufferOne, null, 2) console.log(json) /* { "type": "Buffer", "data": [ 65, 108, 108, 32, 119, 111, 114, 107, 32, 97, 110, 100, 32, 110, 111, 32, 112, 108, 97, 121, 32, 109, 97, 107, 101, 115, 32, 74, 97, 99, 107, 32, 97, 32, 100, 117, 108, 108, 32, 98, 111, 121 ] } */
JSON 指定要转换的对象的类型是 Buffer
及其数据。
let bufferOriginal = Buffer.from(JSON.parse(json).data) console.log(bufferOriginal) // <Buffer 41 6c 6c 20 77 6f 72 6b 20 61 6e 64 20 6e 6f 20 70 6c 61 79 20 6d 61 6b 65 73 20 4a 61 63 6b 20 61 20 64 75 6c 6c 20 62 6f 79>
console.log(bufferOriginal.toString('utf8')) // All work and no play makes Jack a dull boy
.toString()
不是将缓冲区转换为字符串的唯一方法。此外,默认情况下,它会转换为 utf-8 格式字符串。
另一种将缓冲区转换为字符串的方法是使用 Node.js API 中的 StringDecoder
核心模块。
string_decoder
模块提供了用于将 Buffer
对象解码为字符串(以保留编码的多字节 UTF-8 和 UTF-16 字符的方式)的 API。 上述例子的替代写法如下:
const { StringDecoder } = require('string_decoder') const decoder = new StringDecoder('utf8') let bufferOriginal = Buffer.from(JSON.parse(json).data) console.log(decoder.write(bufferOriginal)) // All work and no play makes Jack a dull boy console.log(decoder.end(bufferOriginal)) // All work and no play makes Jack a dull boy
当 Buffer
实例被写入 StringDecoder
实例时,会使用内部的缓冲区来确保解码后的字符串不包含任何不完整的多字节字符。 这些都保存在缓冲区中,直到下一次调用 stringDecoder.write()
或调用 stringDecoder.end()
"]
.0 이전에는 새 버퍼를 생성하기 위해 new
키워드를 사용하여 생성자를 호출했습니다. rrreeev6.0 이후에는 새 버퍼 인스턴스를 생성했습니다.
new Buffer()
생성자는 더 이상 사용되지 않으며 별도의 Buffer.from()
, Buffer.alloc()
및 Buffer .allocUnsafe() 메소드 교체. 🎜🎜자세한 내용은 <a href="https://nodejs.org/api/buffer.html" target="_blank" ref="nofollow noopener noreferrer"><strong>공식 문서</strong>를 참조하세요. 🎜. 🎜<h3 data-id="heading-0"><strong>버퍼를 JSON으로 변환</strong></h3>🎜버퍼를 JSON으로 변환할 수 있습니다. 🎜rrreee🎜JSON은 변환할 개체 유형이 <code>Buffer
및 해당 데이터임을 지정합니다. 🎜.toString()
이 버퍼를 문자열로 변환하는 유일한 방법은 아닙니다. 또한 기본적으로 utf-8 형식 문자열로 변환됩니다. 🎜🎜버퍼를 문자열로 변환하는 또 다른 방법은 Node.js API의 StringDecoder
핵심 모듈을 사용하는 것입니다. 🎜🎜string_decoder
🎜 모듈은 변환 방법을 제공합니다. 버퍼 인코딩된 멀티바이트 UTF-8 및 UTF-16 문자를 유지하는 방식으로 개체를 문자열로 변환합니다. 위 예에 대한 대안은 다음과 같습니다. 🎜rrreee🎜 Buffer
인스턴스가 StringDecoder
인스턴스에 기록되면 내부 버퍼를 사용하여 디코딩된 문자열이 불완전한 멀티바이트 문자를 포함하지 마세요. 이는 stringDecoder.write()
에 대한 다음 호출 또는 stringDecoder.end()
에 대한 다음 호출까지 버퍼에 유지됩니다. 🎜🎜더 많은 프로그래밍 관련 지식을 보려면 🎜프로그래밍 비디오🎜를 방문하세요! ! 🎜위 내용은 Nodejs의 버퍼를 JSON 형식 및 UTF-8 문자열로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!