Vad är Base64?
Base64 är ett binärt-till-text encoding-schema som omvandlar binär data till en ASCII-sträng. Namnet kommer från att encodingen använder 64 olika tecken för att representera data.
De 64 tecknen
Base64 använder:
- A-Z (26 tecken)
- a-z (26 tecken)
- 0-9 (10 tecken)
-
- och / (2 tecken)
- = (padding)
Totalt 64 tecken som är säkra att använda i de flesta system.
Varför Base64?
Problem som Base64 löser
1. Binär data i text-baserade system Många system är byggda för att hantera text, inte binär data:
- Email (SMTP)
- JSON och XML
- URL query parameters
- HTML och CSS
2. Säker överföring Base64 använder bara tecken som inte tolkas speciellt av olika system:
- Inga whitespace-problem
- Inga problem med olika charset
- Fungerar i URLs (med Base64URL variant)
3. Data embedding Möjliggör att bädda in filer direkt i kod eller markup:
<img src="...">
Hur fungerar Base64?
Encoding Process
- Ta 3 bytes (24 bits) av data
- Dela upp i 4 grupper om 6 bits vardera
- Konvertera varje grupp till ett Base64-tecken
- Lägg till padding om nödvändigt
Exempel: “Hi”
Text: H i
ASCII: 72 105
Binary: 01001000 01101001
Grouped: 010010 000110 1001
Padded: 010010 000110 100100 (padding)
Base64: S G k =
Result: SGk=
Varför blir det större?
Base64 ökar storleken med ~33%:
- 3 bytes → 4 Base64-tecken
- 24 bits → 32 bits (med padding)
- 100 KB fil → 133 KB Base64
Detta är tradeoff för kompatibilitet!
Base64 vs Base64URL
Standard Base64
+ / =
Problematiskt i URLs eftersom dessa tecken har speciell betydelse.
Base64URL
- _ (no padding)
URL-säker variant som används i:
- JWT tokens
- URL parameters
- Filnamn
// Standard Base64
"hello+world/test="
// Base64URL
"hello-world_test"
Vanliga användningsområden
1. Data URLs i HTML/CSS
Bädda in bilder direkt:
<img src="..." alt="Logo">
Fördelar:
- Färre HTTP-requests
- Snabbare laddning för små bilder
- Ingen extern fil att hantera
Nackdelar:
- Större HTML-storlek
- Kan inte cachas separat
- Inte lämpligt för stora bilder
2. API Authentication
Basic Authentication:
const credentials = btoa("username:password");
// "dXNlcm5hbWU6cGFzc3dvcmQ="
fetch("/api/data", {
headers: {
"Authorization": `Basic ${credentials}`
}
});
JWT Tokens:
eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.
eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIn0.
SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c
Varje del är Base64URL-encoded JSON.
3. File Upload Preview
Visa bild innan upload:
function previewImage(file) {
const reader = new FileReader();
reader.onload = (e) => {
const base64 = e.target.result;
document.getElementById("preview").src = base64;
};
reader.readAsDataURL(file);
}
4. Email Attachments
MIME använder Base64 för att skicka bilagor:
Content-Type: image/png
Content-Transfer-Encoding: base64
iVBORw0KGgoAAAANSUhEUgAAAAUA
AAAFCAYAAACNbyblAAAAHElEQVQI
12P4//8/w38GIAXDIBKE0DHxgljN
BAAO9TXL0Y4OHwAAAABJRU5ErkJggg==
5. Lagra binär data i JSON
{
"filename": "document.pdf",
"content": "JVBERi0xLjQKJeLjz9MKMyAwIG9iago8PC9UeXBl...",
"encoding": "base64"
}
6. WebSocket Binary Data
const base64Data = btoa(String.fromCharCode(...new Uint8Array(buffer)));
websocket.send(JSON.stringify({
type: "binary",
data: base64Data
}));
JavaScript Implementation
Browser (Native)
Encoding:
// String to Base64
const encoded = btoa("Hello World");
console.log(encoded); // "SGVsbG8gV29ybGQ="
// Decode
const decoded = atob(encoded);
console.log(decoded); // "Hello World"
Problem med Unicode:
// Detta kommer INTE fungera!
btoa("Hello 👋"); // Error!
// Lösning:
function encodeUnicode(str) {
return btoa(encodeURIComponent(str).replace(/%([0-9A-F]{2})/g,
(match, p1) => String.fromCharCode('0x' + p1)
));
}
function decodeUnicode(str) {
return decodeURIComponent(atob(str).split('').map(
c => '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2)
).join(''));
}
Node.js
// Encoding
const encoded = Buffer.from("Hello World").toString("base64");
console.log(encoded); // "SGVsbG8gV29ybGQ="
// Decoding
const decoded = Buffer.from(encoded, "base64").toString("utf-8");
console.log(decoded); // "Hello World"
// Base64URL
const base64url = encoded
.replace(/\+/g, '-')
.replace(/\//g, '_')
.replace(/=/g, '');
Modern Web API
// TextEncoder/TextDecoder (Unicode-safe)
function base64Encode(str) {
const bytes = new TextEncoder().encode(str);
const binString = String.fromCodePoint(...bytes);
return btoa(binString);
}
function base64Decode(base64) {
const binString = atob(base64);
const bytes = Uint8Array.from(binString, m => m.codePointAt(0));
return new TextDecoder().decode(bytes);
}
Performance Tips
1. Stora filer
För stora filer, använd streaming:
async function encodeFileInChunks(file) {
const chunkSize = 1024 * 1024; // 1MB chunks
const reader = file.stream().getReader();
let result = "";
while (true) {
const { done, value } = await reader.read();
if (done) break;
result += btoa(String.fromCharCode(...value));
}
return result;
}
2. Worker Threads
Flytta encoding till en Web Worker för stora dataset:
// worker.js
self.onmessage = (e) => {
const encoded = btoa(e.data);
self.postMessage(encoded);
};
// main.js
const worker = new Worker('worker.js');
worker.postMessage(largeString);
worker.onmessage = (e) => console.log(e.data);
3. Caching
Cache encoded resultat när möjligt:
const cache = new Map();
function cachedEncode(data) {
const key = data.slice(0, 100); // Sample för key
if (cache.has(key)) {
return cache.get(key);
}
const encoded = btoa(data);
cache.set(key, encoded);
return encoded;
}
Security Considerations
1. Base64 är INTE kryptering!
// FARLIGT - synligt för alla!
const password = btoa("mySecretPassword123");
// "bXlTZWNyZXRQYXNzd29yZDEyMw=="
// Enkelt att dekoda:
atob("bXlTZWNyZXRQYXNzd29yZDEyMw==");
// "mySecretPassword123"
Base64 är encoding, inte encryption. Använd aldrig för att “gömma” känslig data!
2. Validera alltid input
function safeBase64Decode(str) {
// Validera Base64 format
const base64Regex = /^[A-Za-z0-9+/]*={0,2}$/;
if (!base64Regex.test(str)) {
throw new Error("Invalid Base64 string");
}
try {
return atob(str);
} catch (e) {
throw new Error("Failed to decode Base64");
}
}
3. Storleksbegränsningar
const MAX_SIZE = 10 * 1024 * 1024; // 10MB
function encodeWithLimit(data) {
const encoded = btoa(data);
if (encoded.length > MAX_SIZE) {
throw new Error("Encoded data too large");
}
return encoded;
}
Common Pitfalls
1. Unicode-hantering
// Fel - fungerar inte med emoji/unicode
btoa("Hello 🌍"); // Error!
// Rätt - hantera unicode korrekt
btoa(unescape(encodeURIComponent("Hello 🌍")));
2. Newlines i output
Vissa Base64-implementationer lägger till newlines:
const encoded = "SGVsbG8g\nV29ybGQ=";
const cleaned = encoded.replace(/\n/g, "");
3. Padding
// Standard Base64 - padding required
"SGVsbG8=" // OK
// Base64URL - no padding
"SGVsbG8" // OK
// Mixed - problematic!
"SGVsbG8-" // Fel!
Best Practices
1. Använd rätt variant
- Standard Base64: Email, MIME, general encoding
- Base64URL: JWTs, URL parameters, filenames
- Base64 no-padding: Vissa databaser, kompakt format
2. Dokumentera encoding
interface FileData {
filename: string;
content: string; // Base64-encoded binary data
encoding: "base64";
mimeType: string;
}
3. Hantera fel graciöst
function tryDecode(base64String) {
try {
return {
success: true,
data: atob(base64String)
};
} catch (error) {
return {
success: false,
error: "Invalid Base64 string"
};
}
}
4. Överväg alternativ för stora filer
För filer > 5MB, överväg:
- Direct file upload (multipart/form-data)
- Chunked upload
- Signed URLs (S3, CloudFlare R2)
- Binary WebSocket
Verktyg
Använd våra online-verktyg för Base64:
- Base64 Encoder/Decoder - Grundläggande encoding/decoding
- Base64URL Converter - URL-säker variant
- Image to Base64 - Konvertera bilder till data URLs
Slutsats
Base64 är ett ovärderligt verktyg för moderna webbutvecklare:
Använd Base64 för:
- ✅ Små bilder i HTML/CSS
- ✅ API authentication headers
- ✅ JWT tokens
- ✅ Email attachments
- ✅ Binär data i JSON
Undvik Base64 för:
- ❌ Kryptering eller säkerhet
- ❌ Stora filer (>5MB)
- ❌ Data som behöver sökas/indexeras
- ❌ När direkta HTTP-uploads är möjliga
Kom ihåg: Base64 är encoding för kompatibilitet, inte säkerhet eller komprimering!