JS метод Object.btoa()
Загальний опис
Функція btoa() є глобальною функцією, призначеною для кодування даних у рядок, використовуючи кодування Base64. Цей метод приймає рядок як вхідний аргумент і повертає його відповідник, закодований у форматі Base64. Важливо зазначити, що btoa() призначена для роботи з текстовими даними і може призводити до помилок або некоректної поведінки при спробі кодувати бінарні дані.
Кодування у Base64 часто використовується для перетворення даних, які потребують відправлення через мережеві протоколи або включення в URL, оскільки це кодування перетворює двійкові дані на ASCII-рядок. Це корисно, наприклад, при передачі даних, які можуть містити символи, що мають спеціальне значення в URL.
Ось простий приклад використання btoa():
let string = 'Hello World!';
let encodedString = btoa(string);
console.log(encodedString); // Виводить: SGVsbG8gV29ybGQh
У цьому прикладі вхідний рядок Hello World! перетворюється на рядок, закодований у форматі Base64.
Для більш складних сценаріїв, таких як кодування даних, що містять символи не з ASCII, використання btoa() може вимагати додаткових кроків, наприклад, перетворення рядка у формат UTF-8 перед кодуванням. Наприклад:
function utf8ToB64(str) {
    return btoa(unescape(encodeURIComponent(str)));
}
let string = 'Привіт Світ!';
let encodedString = utf8ToB64(string);
console.log(encodedString); // Виводить закодований рядок у форматі Base64
У цьому прикладі спочатку рядок перетворюється у формат UTF-8 за допомогою encodeURIComponent(), а потім перетворюється з escape перед кодуванням у Base64.
btoa() також може застосовуватися для кодування даних, які будуть включені в HTML-документи або CSS, наприклад, для вставки зображень у форматі Base64 безпосередньо у CSS-стилі або HTML-розмітку:
let imageData = 'data:image/png;base64,iVBORw0KGgo...';
let css = `background-image: url("${imageData}");`;
У цьому випадку зображення, закодоване у форматі Base64, вставляється безпосередньо у CSS.
На завершення, важливо пам'ятати, що, хоча кодування Base64 є корисним для безпечної передачі та вбудовування даних, воно не є методом шифрування і не повинно використовуватися як таке. Кодування Base64 збільшує розмір даних приблизно на 33%, тому слід слід використовувати його обережно, особливо при передачі великих об'ємів даних, щоб уникнути непотрібного збільшення трафіку мережі. Крім того, варто звернути увагу на обмеження розміру URL в різних браузерах при включенні довгих рядків, закодованих у Base64, у веб-запити.
| Порада: | 
 | 
| Порада: | Хоча  | 
| Порада: | Для декодування рядків, закодованих за допомогою  | 
Синтаксис
btoa(stringToEncode)Параметри
- *stringToEncode
- Рядок у форматі двійкового коду для кодування. 
Return
- string
- Повертає рядок ASCII, який містить представлення Base64 для рядка, що був закодований у методі - stringToEncode.
Переглядачі
| Переглядач | |||||
|---|---|---|---|---|---|
| 4 | 1 | 3 | 10.5 | 12 | 
| Переглядач | ||||
|---|---|---|---|---|
| 37 | 18 | 4 | 1 | 
| Переглядач | ||
|---|---|---|
| 16.0.0 | 1.0 | 
Приклади
У цьому прикладі є текстове поле, де можна ввести текст для кодування, кнопка "Кодувати в Base64" і відображення результату кодування. При натисканні на кнопку метод btoa() використовується для кодування введеного тексту у формат Base64, і результат виводиться на сторінці.
У цьому прикладі метод btoa() використовується для кодування рядка originalText у формат Base64. Результат кодування виводиться у консоль.
// Оригінальний текст, який ми хочемо закодувати
const originalText = "Привіт, це приклад використання методу btoa()";
// Використовуємо метод btoa() для кодування тексту у формат Base64
const encodedText = btoa(originalText);
console.log("Закодований текст у форматі Base64:", encodedText);
У цьому прикладі ми завантажуємо зображення з сервера, використовуючи об'єкт Image(), та після завантаження зображення використовуємо метод toDataURL() canvas для отримання зображення у форматі Base64. Результат виводиться у консоль і зображення додається на сторінку.
// Створюємо новий об'єкт зображення
const image = new Image();
// Встановлюємо шлях до зображення на сервері
image.src = "url_до_зображення.jpg";
// Обробляємо подію завантаження зображення
image.onload = function () {
  // Створюємо об'єкт canvas для роботи з зображенням
  const canvas = document.createElement("canvas");
  canvas.width = image.width;
  canvas.height = image.height;
  // Отримуємо контекст canvas
  const ctx = canvas.getContext("2d");
  // Відображаємо зображення на canvas
  ctx.drawImage(image, 0, 0, image.width, image.height);
  // Отримуємо дані зображення у форматі Base64
  const imageData = canvas.toDataURL("image/jpeg");
  // Виводимо дані у форматі Base64
  console.log("Зображення у форматі Base64:", imageData);
};
// Додаємо зображення на сторінку
document.body.appendChild(image);
