本文汇总 JavaScript 在浏览器与 Node.js 环境中的 Base64 用法,
涵盖 btoa/atob、UTF-8 安全处理方法、URL 安全变体,
以及字符串、二进制与文件相关示例。
Base64 使用可打印字符来表示二进制数据。
在浏览器中,btoa() 将二进制字符串编码为 Base64,atob() 负责解码;
涉及非 ASCII 文本时,请配合 TextEncoder/TextDecoder 进行 UTF-8 安全处理。
在 Node.js 中,请使用 Buffer。
window.btoa(binaryString) → Base64 字符串(浏览器)window.atob(base64) → 二进制字符串(浏览器)TextEncoder / TextDecoder(浏览器端 UTF-8 字节处理)Buffer.from(data).toString('base64') / Buffer.from(b64, 'base64')(Node.js)// Encode a JS string (UTF-8) to Base64
function encodeBase64(text) {
const bytes = new TextEncoder().encode(text);
let binary = "";
for (let i = 0; i < bytes.length; i++) binary += String.fromCharCode(bytes[i]);
return btoa(binary);
}
// Decode Base64 to JS string (UTF-8)
function decodeBase64(b64) {
const binary = atob(b64);
const bytes = new Uint8Array(binary.length);
for (let i = 0; i < binary.length; i++) bytes[i] = binary.charCodeAt(i);
return new TextDecoder('utf-8', { fatal: false }).decode(bytes);
}
console.log(encodeBase64('Hello, 世界')); // SGVsbG8sIOS4lueVjw==
console.log(decodeBase64('SGVsbG8sIOS4lueVjw=='));
// String → Base64
const b64 = Buffer.from('Hello, 世界', 'utf8').toString('base64');
console.log(b64); // SGVsbG8sIOS4lueVjw==
// Base64 → String
const text = Buffer.from('SGVsbG8sIOS4lueVjw==', 'base64').toString('utf8');
console.log(text); // Hello, 世界
// Replace +/ with -_, optionally remove padding =
function toUrlSafe(b64, stripPadding = false) {
let s = b64.replace(/\+/g, '-').replace(/\//g, '_');
return stripPadding ? s.replace(/=+$/g, '') : s;
}
function fromUrlSafe(urlSafeB64) {
let s = urlSafeB64.replace(/-/g, '+').replace(/_/g, '/');
// pad to length % 4 === 0
while (s.length % 4) s += '=';
return s;
}
const safe = toUrlSafe('YWJj+/==');
console.log(safe);
console.log(fromUrlSafe(safe));
// File → Base64 (data URL or raw Base64)
function fileToBase64(file, callback) {
const reader = new FileReader();
reader.onload = () => {
const dataUrl = reader.result; // e.g. "..."
const base64 = String(dataUrl).split(',')[1];
callback({ dataUrl, base64 });
};
reader.readAsDataURL(file);
}
// Base64 → Blob (download)
function base64ToBlob(b64, contentType = 'application/octet-stream') {
const binary = atob(b64);
const bytes = new Uint8Array(binary.length);
for (let i = 0; i < binary.length; i++) bytes[i] = binary.charCodeAt(i);
return new Blob([bytes], { type: contentType });
}
TextEncoder/TextDecoder。=,解码前需补齐。Buffer,更可靠且性能更好。