🛠️

Whiz Tools

Build • Create • Innovate

Base64 Billedekoder og -viser | Konverter Base64 til billeder

Dekodér og forhåndsvis base64-kodede billedstrenge øjeblikkeligt. Understøtter JPEG, PNG, GIF og andre almindelige formater med fejlhåndtering for ugyldige input.

Base64 Billedekoder og Visning

Indsæt en base64-kodet billedestreng og dekod det for at se billedet.

Billedpreview

Intet billede at vise. Indsæt en base64-streng for at se det dekodet automatisk.

Understøtter JPEG, PNG, GIF og andre almindelige billedformater.

Instruktioner

1. Indsæt en base64-kodet billedestreng i tekstområdet ovenfor.

2. Billedet vil blive dekodet automatisk, mens du skriver, eller klik på knappen 'Dekod Billede'.

3. Det dekodede billede vises i preview-området nedenfor.

Bemærk: Strengen bør starte med 'data:image/' for bedst resultat, men værktøjet vil forsøge at dekode strenge uden dette præfiks også.

📚

Dokumentation

Base64 Billedekoder og Viewer

Introduktion

Base64 er et binært-til-tekst kodningssystem, der repræsenterer binære data i et ASCII-strengformat. Det bruges ofte til at indlejre billeddata direkte i HTML, CSS, JavaScript, JSON og andre tekstbaserede formater, hvor binære data ikke kan inkluderes direkte. Dette værktøj giver dig mulighed for at dekode base64-kodede billedstrenge og se de resulterende billeder direkte i din browser.

Base64-kodning øger datastørrelsen med cirka 33% sammenlignet med den oprindelige binære, men det muliggør, at billeder kan inkluderes direkte i tekstbaserede dokumenter uden at kræve separate fil-downloads. Dette kan være særligt nyttigt for små billeder som ikoner, logoer eller enkle grafik, hvor bekvemmeligheden ved indlejring opvejer størrelsesforøgelsen.

Vores Base64 Billedekoder værktøj giver en simpel grænseflade, hvor du kan indsætte en base64-kodet billedstreng og straks se det dekodede billede. Det understøtter alle almindelige billedformater, herunder JPEG, PNG, GIF, WebP og SVG, og kan håndtere både data-URL-format (med data:image/... præfiks) og rå base64-strenge.

Tekniske Detaljer

Base64 Kodningsformat

Base64-kodning konverterer binære data til et sæt af 64 ASCII-tegn (A-Z, a-z, 0-9, +, og /), med = brugt til padding. For billeder på nettet er base64-data typisk formateret som en data-URL med følgende struktur:

1data:[<media type>][;base64],<data>
2

For eksempel kan et base64-kodet PNG-billede se således ud:

1data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==
2

Komponenterne i dette format er:

  • data: - URL-skematik
  • image/png - MIME-typen for dataene
  • ;base64 - Kodningsmetoden
  • , - En afgrænser mellem headeren og dataene
  • De faktiske base64-kodede data

Dekodningsproces

Når en base64 billedstreng dekodes, sker følgende trin:

  1. Strengen parses for at identificere, om den indeholder et data-URL-præfiks
  2. Hvis et præfiks findes, udtrækkes MIME-typen for at bestemme billedformatet
  3. Base64-dataportionen isoleres og dekodes til binære data
  4. De binære data konverteres til en Blob eller et objekt-URL, der kan vises som et billede

Hvis input ikke inkluderer et data-URL-præfiks, forsøger dekoderen at behandle det som rå base64-data og udleder billedtypen fra den dekodede binære header eller standardiserer til PNG.

Understøttede Billedformater

Dette værktøj understøtter alle almindelige webbilledformater:

FormatMIME-typeTypiske Anvendelsestilfælde
JPEGimage/jpegFotos, komplekse billeder med mange farver
PNGimage/pngBilleder, der kræver gennemsigtighed, screenshots, grafik
GIFimage/gifEnkle animationer, billeder med begrænset farve
WebPimage/webpModerne format med bedre kompression end JPEG/PNG
SVGimage/svg+xmlVektorgrafik, skalerbare ikoner og illustrationer

Anvendelsestilfælde

Base64-kodede billeder har flere praktiske anvendelser inden for webudvikling og derudover:

  1. Indlejring af billeder i HTML/CSS/JS: Reducerer HTTP-anmodninger ved at inkludere billeder direkte i din kode, hvilket kan forbedre indlæsningstider for små billeder.

  2. E-mail skabeloner: Sikrer, at billeder vises korrekt i e-mailklienter, der blokerer for eksterne billeder som standard.

  3. Enkeltfil-applikationer: Opretter selvstændige HTML-applikationer, hvor alle ressourcer er indlejret i en enkelt fil.

  4. API-svar: Inkluderer billeddata direkte i JSON-svar uden at kræve separate billede-endepunkter.

  5. Data-URI'er i CSS: Indlejrer små ikoner og baggrundsbilleder direkte i CSS-filer.

  6. Canvas-manipulationer: Lettere at gemme og overføre canvas-billeddata.

  7. Offline-applikationer: Gemmer billeder som tekststrenge i localStorage eller IndexedDB.

Ydelsesovervejelser

Selvom base64-kodning tilbyder bekvemmelighed, kommer det med ulemper:

  • Forøget filstørrelse: Base64-kodning øger datastørrelsen med cirka 33%.
  • Ingen browser-caching: Indlejrede billeder kan ikke caches separat som eksterne billedfiler.
  • Parsing-overhead: Browsere skal dekode base64-strengen, før de gengiver.
  • Vedligeholdelsesudfordringer: Indlejrede billeder er sværere at opdatere end refererede filer.

For optimal ydeevne anbefales base64-kodning generelt kun for små billeder (under 10KB). Større billeder er normalt bedre tjent som separate filer, der kan caches og optimeres korrekt.

Alternativer

Flere alternativer til base64-kodning findes til forskellige anvendelsestilfælde:

  1. SVG inline indlejring: For vektorgrafik giver inline SVG ofte bedre ydeevne og fleksibilitet end base64-kodede SVG.

  2. WebP og moderne billedformater: Disse giver bedre kompression end base64-kodede JPEG/PNG.

  3. Billedsprites: Kombinerer flere små billeder til en enkelt fil og bruger CSS-positionering.

  4. CDN'er (Content Delivery Networks): For produktionssider er det ofte mere effektivt at servere optimerede billeder fra en CDN.

  5. Datakompression: For overførsel af store mængder binære data er specialiserede kompressionsalgoritmer som gzip eller Brotli mere effektive end base64.

Kodeeksempler

Her er eksempler på at arbejde med base64-kodede billeder i forskellige programmeringssprog:

1// Konverter et billede til base64 i JavaScript (browser)
2function imageToBase64(imgElement) {
3  const canvas = document.createElement('canvas');
4  canvas.width = imgElement.width;
5  canvas.height = imgElement.height;
6  
7  const ctx = canvas.getContext('2d');
8  ctx.drawImage(imgElement, 0, 0);
9  
10  // Få som data URL (base64-streng)
11  return canvas.toDataURL('image/png');
12}
13
14// Vis et base64 billede
15function displayBase64Image(base64String) {
16  const img = new Image();
17  
18  // Håndter strenge uden data URL-præfiks
19  if (!base64String.startsWith('data:')) {
20    base64String = `data:image/png;base64,${base64String}`;
21  }
22  
23  img.src = base64String;
24  document.body.appendChild(img);
25}
26

HTML Implementering

Her er hvordan man indlejrer et base64 billede direkte i HTML:

1<!-- Indlejring af et base64 billede direkte i HTML -->
2<img src="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==" alt="Base64 kodet billede">
3
4<!-- Brug af CSS med et base64 baggrundsbillede -->
5<style>
6.base64-bg {
7  background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==');
8  width: 100px;
9  height: 100px;
10}
11</style>
12<div class="base64-bg"></div>
13

Historie

Base64-kodning har sine rødder i udviklingen af elektroniske mailsystemer i 1970'erne. Det blev designet til at løse problemet med at overføre binære data gennem systemer, der kun var designet til at håndtere ASCII-tekst.

Kodningssystemet blev formaliseret i 1987 med offentliggørelsen af RFC 989, som definerede standarden for Privacy Enhanced Mail (PEM). Dette blev senere opdateret i RFC 1421 og andre relaterede standarder. Begrebet "base64" stammer fra det faktum, at kodningen bruger 64 forskellige ASCII-tegn til at repræsentere binære data.

I forbindelse med webudvikling blev base64-kodede billeder populære med fremkomsten af data-URI'er, som først blev foreslået i RFC 2397 i 1998. Dette tillod binære data at blive inkluderet direkte i HTML, CSS og andre webdokumenter.

Brugen af base64-kodede billeder i webudvikling blev mere udbredt i midten af 2000'erne, da udviklere søgte måder at reducere HTTP-anmodninger og forbedre indlæsningstider. Teknikken blev især taget i brug under stigningen af mobil webudvikling, hvor det var afgørende at minimere anmodninger på langsommere mobile forbindelser.

I dag forbliver base64-kodning et vigtigt værktøj i webudvikling, selvom dens brug er blevet mere målrettet, efterhånden som bedste praksis har udviklet sig. Moderne tilgange har tendens til at bruge base64-kodning selektivt til små, kritiske billeder, mens der udnyttes mere effektive leveringsmetoder som HTTP/2 til større aktiver.

Referencer

  1. RFC 4648: The Base16, Base32, and Base64 Data Encodings
  2. RFC 2397: The "data" URL scheme
  3. MDN Web Docs: data URIs
  4. CSS-Tricks: Data URIs
  5. Base64 Billedekoder
  6. Can I Use: Data URIs
  7. Web Performance: When to Base64 Encode Images (and When Not To)