


Wie konvertiere ich den Puffer in Nodejs in das JSON-Format und die UTF-8-Zeichenfolge?
Wie konvertiere ich den Puffer in Nodejs in das JSON-Format und die UTF-8-Zeichenfolge? Der folgende Artikel stellt Ihnen die Methode zum Konvertieren von Puffer- und JSON-Formaten in Nodejs sowie die Methode zum Konvertieren von Puffer in einen UTF-8-String vor.
Node.js unterscheidet sich von browserbasiertem JavaScript, da Node bereits vor dem Vorschlag von ArrayBuffer
im ES6-Entwurf eine Möglichkeit hatte, Binärdaten zu verarbeiten. In Node ist die Klasse Buffer
(Puffer) die primäre Datenstruktur, die von den meisten E/A-Vorgängen verwendet wird. Es handelt sich um rohe Binärdaten, die außerhalb des V8-Heaps zugewiesen werden und deren Größe nach der Zuordnung nicht geändert werden kann. [Empfohlenes Lernen: „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()
方法替换。
更多信息可以阅读官方文档。
将 Buffer 转换为 JSON
缓冲区可以转换为 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
及其数据。
将 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>
将 Buffer 转换为 UTF-8 字符串
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()
"]
in Node v6 Vor .0 haben wir zum Erstellen eines neuen Puffers einfach den Konstruktor mit dem Schlüsselwort new
aufgerufen: rrreeeNach v6.0 zum Erstellen einer neuen Pufferinstanz:
new Der Buffer()
-Konstruktor wurde zugunsten der separaten Buffer.from()
, Buffer.alloc()
und Buffer .allocUnsafe() Methodenersetzung. 🎜🎜Weitere Informationen finden Sie in der <a href="https://nodejs.org/api/buffer.html" target="_blank" ref="nofollow noopener noreferrer"><strong>Offizielle Dokumentation</strong> 🎜. 🎜<h3 id="strong-Puffer-in-JSON-konvertieren-strong"><strong>Puffer in JSON konvertieren</strong></h3>🎜Puffer können in JSON konvertiert werden. 🎜rrreee🎜JSON gibt an, dass der Typ des zu konvertierenden Objekts <code>Puffer
und seine Daten sind. 🎜JSON in Puffer konvertieren
rrreeePuffer in UTF -8 konvertieren String
rrreee🎜.toString()
ist nicht die einzige Möglichkeit, einen Puffer in einen String umzuwandeln. Darüber hinaus wird es standardmäßig in eine Zeichenfolge im UTF-8-Format konvertiert. 🎜🎜Eine andere Möglichkeit, einen Puffer in einen String umzuwandeln, ist die Verwendung des Kernmoduls StringDecoder
aus der Node.js-API. 🎜🎜string_decoder
🎜 Das Modul bietet eine Möglichkeit zum Konvertieren Puffer-Objekte in Zeichenfolgen, sodass codierte Multibyte-UTF-8- und UTF-16-Zeichen erhalten bleiben. Eine Alternative zum obigen Beispiel ist wie folgt: 🎜rrreee🎜Wenn eine Buffer
-Instanz in eine StringDecoder
-Instanz geschrieben wird, wird der interne Puffer verwendet, um sicherzustellen, dass die dekodierte Zeichenfolge dies tut enthalten keine unvollständigen Multibyte-Zeichen. Diese bleiben im Puffer bis zum nächsten Aufruf von stringDecoder.write()
oder dem nächsten Aufruf von stringDecoder.end()
. 🎜🎜Weitere Kenntnisse zum Thema Programmierung finden Sie unter: 🎜Programmiervideos🎜! ! 🎜Das obige ist der detaillierte Inhalt vonWie konvertiere ich den Puffer in Nodejs in das JSON-Format und die UTF-8-Zeichenfolge?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Speichers und Garbage Collectors (GC) der NodeJS V8-Engine. Ich hoffe, er wird Ihnen hilfreich sein!

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Die Auswahl eines Docker-Images für Node mag trivial erscheinen, aber die Größe und potenziellen Schwachstellen des Images können erhebliche Auswirkungen auf Ihren CI/CD-Prozess und Ihre Sicherheit haben. Wie wählen wir also das beste Node.js-Docker-Image aus?

Node 19 wurde offiziell veröffentlicht. Dieser Artikel wird Ihnen eine detaillierte Erklärung der 6 Hauptfunktionen von Node.js 19 geben. Ich hoffe, er wird Ihnen hilfreich sein!

Wie führt Node.js GC (Garbage Collection) durch? Der folgende Artikel führt Sie durch.

Öffnungsmethode: 1. Mit einem Texteditor öffnen: Sie können einen beliebigen Texteditor (z. B. Notepad, Sublime Text, Atom usw.) verwenden, um die JSON-Datei zu öffnen. Doppelklicken Sie einfach auf den Dateinamen und wählen Sie Ihren bevorzugten Editor aus, um ihn zu öffnen. 2. Öffnen Sie ihn mit einem Webbrowser: Viele moderne Browser (wie Chrome, Firefox, Safari usw.) können JSON-Dateien direkt öffnen zum Parsen: JSON-Dateien können mithilfe von Bibliotheken oder Modulen für die entsprechende Sprache geöffnet und analysiert werden.

Die Ereignisschleife ist ein grundlegender Bestandteil von Node.js und ermöglicht die asynchrone Programmierung, indem sie sicherstellt, dass der Hauptthread nicht blockiert wird. Das Verständnis der Ereignisschleife ist für die Erstellung effizienter Anwendungen von entscheidender Bedeutung. Der folgende Artikel wird Ihnen ein detailliertes Verständnis der Ereignisschleife in Node vermitteln. Ich hoffe, er wird Ihnen hilfreich sein!
