Uint8Array.prototype.setFromBase64()
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Die setFromBase64()
Methode von Uint8Array
Instanzen befüllt dieses Uint8Array
Objekt mit Bytes aus einem base64-kodierten String und gibt ein Objekt zurück, das angibt, wie viele Bytes gelesen und geschrieben wurden.
Diese Methode eignet sich am besten zum Befüllen eines vorher zugewiesenen Array-Puffers. Wenn Sie einfach ein neues Uint8Array
Objekt aus einem base64-kodierten String erstellen möchten, verwenden Sie stattdessen die statische Methode Uint8Array.fromBase64()
.
Syntax
setFromBase64(string)
setFromBase64(string, options)
Parameter
string
-
Ein base64 String, der Bytes kodiert, die in ein
Uint8Array
geschrieben werden sollen. Er hat die gleichen Anforderungen wie derstring
-Parameter vonUint8Array.fromBase64()
. Beachten Sie, dass der String nur bis zu dem Punkt gelesen wird, an dem das Array gefüllt ist, sodass jede ungültige base64-Syntax danach ignoriert wird. options
Optional-
Ein Objekt, das den Interpretationsprozess des base64-Strings anpasst. Es hat die gleichen Anforderungen wie der
options
-Parameter vonUint8Array.fromBase64()
.
Rückgabewert
Ein Objekt, das die folgenden Eigenschaften enthält:
read
-
Die Anzahl der base64-Zeichen, die aus dem Eingabestring gelesen wurden. Wenn die dekodierten Daten in das Array passen, entspricht dies der Länge des Eingabestrings (einschließlich Padding); andernfalls ist es die Länge bis zum letzten vollständigen 4-Zeichen-Chunk, der in das Array passt. Chunks werden niemals geteilt (weil die verbleibenden Bits nicht teilweise in das base64 "zurückgelegt" werden können, ohne es vollständig neu zu kodieren); wenn der nächste Chunk nicht in den verbleibenden Speicherplatz des Arrays passt, wird er vollständig ungelesen, was dazu führt, dass das letzte oder die letzten beiden Bytes des Arrays nicht geschrieben werden.
written
-
Die Anzahl der Bytes, die in das
Uint8Array
geschrieben wurden. Wird niemals größer als diebyteLength
diesesUint8Array
sein.
Ausnahmen
SyntaxError
-
Wird ausgelöst, wenn der Eingabestring Zeichen außerhalb des angegebenen Alphabets enthält oder wenn der letzte Chunk die
lastChunkHandling
-Option nicht erfüllt. TypeError
-
Wird in einem der folgenden Fälle ausgelöst:
- Der Eingabestring ist kein String.
- Das
options
-Objekt ist kein Objekt oderundefined
. - Die Optionen entsprechen nicht den erwarteten Werten oder sind
undefined
.
Beispiele
Dekodieren eines base64-Strings
Dieses Beispiel verwendet die Standardoptionen alphabet
und lastChunkHandling
, um einen base64-String in ein bestehendes Uint8Array
zu dekodieren.
const uint8Array = new Uint8Array(16);
const result = uint8Array.setFromBase64("PGI+ TURO PC9i Pg==");
console.log(result); // { read: 19, written: 10 }
console.log(uint8Array);
// Uint8Array(16) [60, 98, 62, 77, 68, 78, 60, 47, 98, 62, 0, 0, 0, 0, 0, 0]
Dekodieren eines großen Strings in ein kleines Array
Wenn der String mehr Daten enthält, als das Array aufnehmen kann, wird die Methode nur so viele Bytes schreiben, wie das Array aufnehmen kann, ohne Bits zu verwerfen.
const uint8Array = new Uint8Array(8);
const result = uint8Array.setFromBase64("PGI+ TURO PC9i Pg==");
console.log(result); // { read: 9, written: 6 }
console.log(uint8Array);
// Uint8Array(8) [60, 98, 62, 77, 68, 78, 0, 0]
Beachten Sie, wie die letzten beiden Bytes des Arrays nicht geschrieben werden. Um diese beiden Bytes zu dekodieren, müssen wir mindestens drei weitere base64-Zeichen lesen, die 18 Bits darstellen. Diese können nicht in die verbleibenden zwei Bytes des Arrays passen, daher können wir nur 2 Chunks oder 6 Bytes schreiben.
Festlegen von Daten an einem bestimmten Offset
Die setFromBase64()
Methode beginnt immer am Anfang des Uint8Array
zu schreiben. Wenn Sie in die Mitte des Arrays schreiben möchten, können Sie stattdessen in ein TypedArray.prototype.subarray()
schreiben.
const uint8Array = new Uint8Array(16);
// Start writing at offset 2
const result = uint8Array.subarray(2).setFromBase64("PGI+ TURO PC9i Pg==");
console.log(result); // { read: 19, written: 10 }
console.log(uint8Array);
// Uint8Array(16) [0, 0, 60, 98, 62, 77, 68, 78, 60, 47, 98, 62, 0, 0, 0, 0]
Stream-Dekodierung
Dieses Beispiel ist an den ursprünglichen Vorschlag angepasst. Es imitiert die TextDecoder
API mit der stream
-Option. Beachten Sie die Verwendung von lastChunkHandling: "stop-before-partial"
, um unvollständige Chunks zu behandeln.
class Base64Decoder {
#extra = "";
decode(chunk = "", options = {}) {
const opts = { ...options };
// match TextEncoder API
if (opts.stream) {
opts.lastChunkHandling = "stop-before-partial";
}
chunk = this.#extra + chunk;
this.#extra = "";
// For simplicity, allocate new memory every time
// the calculation below is guaranteed to be enough,
// but may be too much if there is whitespace
// if you're really concerned about memory, a TextDecoder style API is a bad choice
let buffer = new Uint8Array(Math.ceil((chunk.length * 3) / 4));
const { read, written } = buffer.setFromBase64(chunk, opts);
buffer = buffer.subarray(0, written);
this.#extra = chunk.slice(read);
return buffer;
}
}
const decoder = new Base64Decoder();
console.log(decoder.decode("SG Vsb ", { stream: true }));
// Uint8Array(3) [72, 101, 108]
console.log(decoder.decode("G8gV29ybGR ", { stream: true }));
// Uint8Array(6) [108, 111, 32, 87, 111, 114]
console.log(decoder.decode(""));
// Uint8Array(2) [108, 100]
Spezifikationen
Specification |
---|
Uint8Array to/from base64 # sec-uint8array.prototype.setfrombase64 |