Response: `bytes()` Methode

Baseline 2025
Newly available

Since January 2025, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.

Hinweis: Diese Funktion ist in Web Workers verfügbar.

Die bytes() Methode des Response Interfaces nimmt einen Response-Stream und liest ihn vollständig aus. Sie gibt ein Promise zurück, das mit einem Uint8Array aufgelöst wird.

Syntax

js
bytes()

Parameter

Keine.

Rückgabewert

Ein Promise, das mit einem Uint8Array aufgelöst wird.

Ausnahmen

DOMException AbortError

Die Anfrage wurde abgebrochen.

TypeError

Ausgelöst aus einem der folgenden Gründe:

RangeError

Es gab ein Problem beim Erstellen des zugehörigen ArrayBuffer. Zum Beispiel, wenn die Datengröße mehr als Number.MAX_SAFE_INTEGER ist.

Beispiele

Abrufen und Dekodieren einer Datei

Der untenstehende Code zeigt, wie Sie eine Textdatei abrufen, den Körper als Uint8Array zurückgeben und dann in einen String dekodieren können.

js
const response = await fetch("https://l40lcif0yj.proxynodejs.usequeue.com/textfile.txt");
const textFile = await response.bytes();
const string = new TextDecoder().decode(textFile);
console.log(string);

Abrufen einer Bilddatei-Signatur

Dieses Beispiel zeigt, wie Sie bytes() verwenden können, um die Signaturbytes einer Reihe von Bilddateien zu lesen und den Typ zu identifizieren.

HTML

Zuerst definieren wir ein <select> Element zur Auswahl des Dateityps mit entsprechenden Werten, die auf die spezifische Datei auf WikiMedia Commons hinweisen.

html
<label for="file-select">Choose a file:</label>

<select name="Files" id="file-select">
  <option value="">--Select an image type--</option>
  <option
    value="https://cebnevlq0d.proxynodejs.usequeue.com/wikipedia/commons/7/70/Example.png">
    PNG
  </option>
  <option
    value="https://cebnevlq0d.proxynodejs.usequeue.com/wikipedia/commons/a/a9/Example.jpg">
    JPG
  </option>
  <option
    value="https://cebnevlq0d.proxynodejs.usequeue.com/wikipedia/commons/8/8f/Example.gif">
    GIF89a
  </option>
</select>

JavaScript

Der Code prüft zuerst, ob die bytes() Methode unterstützt wird. Wenn die Methode unterstützt wird, fügt er einen Event-Handler für das change event auf dem <select> Element hinzu. Wenn sich der Wert ändert, übergibt er den Wert der Auswahl (eine URL für eine Bilddatei) an die unten definierte Methode checkSignature(). Wenn die Methode nicht unterstützt wird, wird diese Information protokolliert.

js
if ("bytes" in Response.prototype) {
  const selectFileElement = document.getElementById("file-select");
  selectFileElement.addEventListener("change", (event) => {
    try {
      checkSignature(event.target.value);
    } catch (e) {
      log(e);
    }
  });
} else {
  log("Response.bytes() not supported");
}

Die Methode checkSignature() wird unten definiert. Diese ruft eine Datei von der angegebenen url ab und verwendet response.bytes(), um deren Inhalt als Byte-Array zu erhalten. Die Anfangsbytes werden dann mit den Anfangssignaturbytes einer Reihe von gängigen Dateitypen verglichen. Der Dateiname und der Dateityp werden dann protokolliert.

js
async function checkSignature(url) {
  if (url === "") return;
  log(`File: ${url}`);
  const response = await fetch(url);
  const image = await response.bytes();

  // File signatures from: https://8itucg9d04.proxynodejs.usequeue.com/wiki/List_of_file_signatures
  const jpgSignature = [0xff, 0xd8, 0xff, 0xe0];
  const pngSignature = [0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a];
  const gif89aSignature = [0x47, 0x49, 0x46, 0x38, 0x39, 0x61];

  if (
    image
      .slice(0, jpgSignature.length)
      .every((byte, index) => byte === jpgSignature[index])
  ) {
    log(`JPG signature: FF D8 FF E0`);
  } else if (
    image
      .slice(0, pngSignature.length)
      .every((byte, index) => byte === pngSignature[index])
  ) {
    log(`PNG signature: 89 50 4E 47 0D 0A 1A 0A`);
  } else if (
    image
      .slice(0, gif89aSignature.length)
      .every((byte, index) => byte === gif89aSignature[index])
  ) {
    log(`GIF (GIF89a) signature: 47 49 46 38 39 61`);
  } else {
    log("Unknown format");
  }
}

Ergebnis

Wählen Sie einen Bildtyp aus der Auswahlliste. Das Protokoll sollte dann den Dateinamen zusammen mit dem Dateityp anzeigen, der aus der Signatur der Datei bestimmt wurde.

Spezifikationen

Specification
Fetch
# dom-body-bytes

Browser-Kompatibilität

Siehe auch