1176 Stimmen

Wie man Base64-Bilder in HTML anzeigt

Ich habe Probleme, ein Base64-Bild inline darzustellen.

Wie kann ich das tun?

<!DOCTYPE html>
<html>
  <head>
    <title>Display Image</title>
  </head>
  <body>
    <img style='display:block; width:100px;height:100px;' id='base64image'
       src='data:image/jpeg;base64, LzlqLzRBQ... <!-- Base64 data -->' />
  </body>
</html>

22voto

Es ist ganz einfach.

Das manuelle Programmieren von base64-Bildern ist (fast) unmöglich, daher gibt es eine Webanwendung, die dies ermöglicht. Hier ist der Link für die Anwendung: https://www.opinionatedgeek.com/codecs/base64decoder (Der Decoder funktioniert sowohl für reguläre als auch für URL-sichere Kodierungen, und er kann Ihren Text/das Dokument dekodieren oder kodieren)

Wie Sie sagen, beginnt es mit data:image/jpeg;base64, . Das nachstehende Beispiel stammt aus Wikipedia, ist aber nur ein Beispiel.

<div>
  <img src="data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAUA
    AAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO
        9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Red dot" />
</div>

Ich weiß, dass es nur einen roten Punkt ausgibt, aber es kann nützlich sein, wenn man nicht genug Platz hat, um die Bilder einzubinden oder ähnliches.

Das einzige Problem ist, dass diese Art der Kodierung sehr lang ist, sie kann bis zu 20 Zeilen lang sein. Ich hoffe, das hilft Ihnen!

20voto

Balaji Punkte 7987

Base64-Daten hinzufügen:

<img src="">

oder

In JavaScript

var id = document.getElementById("image");

id.src = base64Url;

10voto

MolhamStein Punkte 617

Sie können Ihre Daten direkt in eine url Aussage, wie:

src = 'url(imageData)';

Und um die Bilddaten zu erhalten, können Sie die PHP-Funktion verwenden:

$imageContent = file_get_contents("imageDir/" . $imgName);

$imageData = base64_encode($imageContent);

Sie können also den Wert von imageData kopieren und ihn direkt in Ihre URL einfügen und ihn der src Attribut Ihres Bildes.

10voto

Kevin Punkte 2667

Versuchen Sie auch das hier:

let base64="iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==";
let buffer=Uint8Array.from(atob(base64), c => c.charCodeAt(0));
let blob=new Blob([buffer], { type: "image/gif" });
let url=URL.createObjectURL(blob);
let img=document.createElement("img");
img.src=url;
document.body.appendChild(img);

Nicht für die Produktion empfohlen, da es nur mit modernen Browsern kompatibel ist.

8voto

David Spector Punkte 81

Das in einem Daten-URI vorkommende Zeichen + sollte als %2B kodiert werden. Dies ist wie die Kodierung jeder anderen Zeichenfolge in einem URI. Zum Beispiel müssen Argumenttrennzeichen (? und &) kodiert werden, wenn ein URI mit einem Argument als Teil eines anderen URI gesendet wird.

CodeJaeger.com

CodeJaeger ist eine Gemeinschaft für Programmierer, die täglich Hilfe erhalten..
Wir haben viele Inhalte, und Sie können auch Ihre eigenen Fragen stellen oder die Fragen anderer Leute lösen.

Powered by:

X