Base64-afbeeldingen weergeven in HTML

Ik heb problemen met het inline weergeven van een Base64-afbeelding.

Hoe kan ik dat doen?

<!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>

Antwoord 1, autoriteit 100%

Mijn verdachte is natuurlijk de feitelijke Base64-gegevens. Anders lijkt het me goed. Zie deze vioolwaar een soortgelijk schema werkt. U kunt proberen de tekenset op te geven.

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

Antwoord 2, autoriteit 9%

U moet het juiste Content-type, Content-encodingen tekensetopgeven.

Vind ik leuk

data:image/jpeg;charset=utf-8;base64,

volgens de syntaxis van het data-URI-schema:

data:[<media type>][;charset=<character set>][;base64],<data>

Antwoord 3, autoriteit 4%

Als je PHP aan de achterkant hebt, kun je deze code gebruiken:

$image = 'http://images.itracki.com/2011/06/favicon.png';
// Read image path, convert to base64 encoding
$imageData = base64_encode(file_get_contents($image));
// Format the image SRC:  data:{mime};base64,{data};
$src = 'data: ' . mime_content_type($image) . ';base64,' . $imageData;
// Echo out a sample image
echo '<img src="' . $src . '">';

Antwoord 4, autoriteit 2%

Dit toont een afbeelding van Base64-gegevens:

<style>
    .logo {
        width: 290px;
        height: 63px;
        background: url(-paste-Base64-data-here) no-repeat;
    }
</style>
<div class="logo"></div>

Antwoord 5

U kunt uw gegevens rechtstreeks in een url-statement plaatsen, zoals:

src = 'url(imageData)';

En om de afbeeldingsgegevens te krijgen, kunt u de PHP-functie gebruiken:

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

Je kunt dus de waarde van imageData kopiëren en deze rechtstreeks in je URL plakken en toewijzen aan het src-kenmerk van je afbeelding.


Antwoord 6

Het +-teken dat voorkomt in een gegevens-URI moet worden gecodeerd als %2B. Dit is vergelijkbaar met het coderen van elke andere tekenreeks in een URI. Scheidingstekens voor argumenten (? en &) moeten bijvoorbeeld worden gecodeerd wanneer een URI met een argument wordt verzonden als onderdeel van een andere URI.


Antwoord 7

Probeer deze ook eens:

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);

Niet aanbevolen voor productie omdat het alleen compatibel is met moderne browsers.


Antwoord 8

Het lijkt erop dat er een fout zit in uw gegevens-URL.

U kunt deze online Base64-codering/ Base64-decoderingstoolom uw afbeeldingen te coderen voor insluiting:
http://base64online.org/encode/

Vink de optie “Formatteren als gegevens-URL” aan om base64-gegevens op te maken als URL.


Antwoord 9

Base64-gegevens toevoegen:

<img src=""></img>

Antwoord 10

Base64-afbeelding opslaan als een variabele en deze weergeven met gewone HTML en JavaScript:

<img id="afbeelding"/>
<script>
var ticket = {
      "validationDataValidDate": "2019-05-30",

Other episodes