Кодувальник і декодувальник Base64: Перетворення тексту в/з Base64
Безкоштовний онлайн інструмент для кодування тексту в Base64 або декодування рядків Base64 назад у текст. Підтримує стандартне та безпечне для URL кодування Base64 з миттєвим перетворенням.
Кодувальник/Декодувальник Base64
Перетворення тексту в кодування Base64 та назад
Документація
Base64 Кодувальник та Декодувальник
Вступ
Base64 — це схема кодування бінарних даних у текстовий формат, яка представляє бінарні дані у форматі ASCII. Вона призначена для передачі даних, що зберігаються у бінарних форматах, через канали, які надійно підтримують лише текстовий контент. Кодування Base64 перетворює бінарні дані на набір з 64 символів (відповідно до назви), які можна безпечно передавати через текстові протоколи без пошкодження даних.
Сет символів Base64 складається з:
- Великі літери A-Z (26 символів)
- Маленькі літери a-z (26 символів)
- Цифри 0-9 (10 символів)
- Два додаткові символи, зазвичай "+" та "/" (2 символи)
Цей інструмент дозволяє вам легко кодувати текст у формат Base64 або декодувати рядки Base64 назад у їх оригінальний текст. Це особливо корисно для розробників, ІТ-фахівців та всіх, хто працює з даними, які потрібно передавати безпечно через текстові канали.
Як працює кодування Base64
Процес кодування
Кодування Base64 працює, перетворюючи кожну групу з трьох байтів (24 біти) бінарних даних у чотири символи Base64. Процес складається з наступних кроків:
- Перетворити вхідний текст у його бінарне представлення (використовуючи кодування ASCII або UTF-8)
- Групувати бінарні дані в шматки по 24 біти (3 байти)
- Розділити кожну 24-бітну групу на чотири 6-бітні групи
- Перетворити кожну 6-бітну групу у відповідний символ Base64
Коли довжина вхідних даних не ділиться на 3, додається заповнення символами "=" для підтримки співвідношення 4:3 між довжинами виходу та входу.
Математичне представлення
Для послідовності байтів відповідні символи Base64 обчислюються як:
Де представляє -й символ у алфавіті Base64.
Процес декодування
Декодування Base64 перевертає процес кодування:
- Перетворити кожен символ Base64 у його 6-бітне значення
- Конкатенувати ці 6-бітні значення
- Групувати біти в 8-бітні шматки (байти)
- Перетворити кожен байт у відповідний символ
Заповнення
Коли кількість байтів для кодування не ділиться на 3, застосовується заповнення:
- Якщо залишився один байт, він перетворюється на два символи Base64, за якими йдуть "=="
- Якщо залишилися два байти, вони перетворюються на три символи Base64, за якими йде "="
Приклад
Давайте закодуємо текст "Hello" у Base64:
- ASCII представлення "Hello": 72 101 108 108 111
- Бінарне представлення: 01001000 01100101 01101100 01101100 01101111
- Групування в 6-бітні шматки: 010010 000110 010101 101100 011011 000110 1111
- Останній шматок має лише 4 біти, тому ми заповнюємо нулями: 010010 000110 010101 101100 011011 000110 111100
- Перетворення в десяткову систему: 18, 6, 21, 44, 27, 6, 60
- Пошук у алфавіті Base64: S, G, V, s, b, G, 8
- Результат: "SGVsbG8="
Зверніть увагу на заповнення "=" в кінці, оскільки довжина вхідних даних (5 байтів) не ділиться на 3.
Формула
Загальна формула для обчислення довжини рядка, закодованого в Base64:
Де представляє функцію округлення до найближчого цілого числа (округлення вгору).
Сфери використання
Кодування Base64 широко використовується в різних додатках:
-
Email вкладення: MIME (Multipurpose Internet Mail Extensions) використовує Base64 для кодування бінарних вкладень в електронній пошті.
-
URL дані: Вбудовування малих зображень, шрифтів або інших ресурсів безпосередньо в HTML, CSS або JavaScript, використовуючи схему URL
data:
. -
API комунікації: Безпечно передавати бінарні дані в JSON навантаженнях або інших текстових форматах API.
-
Зберігання бінарних даних у текстових форматах: Коли бінарні дані потрібно зберігати в XML, JSON або інших текстових форматах.
-
Системи аутентифікації: Базова аутентифікація в HTTP використовує кодування Base64 (хоча це не для безпеки, а лише для кодування).
-
Криптографія: Як частина різних криптографічних протоколів і систем, часто для кодування ключів або сертифікатів.
-
Значення cookie: Кодування складних структур даних для зберігання в cookie.
Альтернативи
Хоча Base64 широко використовується, існують альтернативи, які можуть бути більш доречними в певних ситуаціях:
-
Безпечний для URL Base64: Варіант, який використовує "-" і "_" замість "+" і "/" для уникнення проблем з кодуванням URL. Корисно для даних, які будуть включені в URL.
-
Base32: Використовує набір з 32 символів, що призводить до більшої виходу, але з кращою читабельністю для людини та нечутливістю до регістру.
-
Шістнадцяткове кодування: Просте перетворення в шістнадцяткову систему, що є менш ефективним (подвоює розмір), але дуже простим і широко підтримуваним.
-
Бінарна передача: Для великих файлів або коли ефективність є критично важливою, безпосередні бінарні протоколи передачі, такі як HTTP з відповідними заголовками Content-Type, є переважними.
-
Стиснення + Base64: Для великих текстових даних стиснення перед кодуванням може зменшити збільшення розміру.
-
Серіалізація JSON/XML: Для структурованих даних використання рідної серіалізації JSON або XML може бути більш доречним, ніж кодування Base64.
Історія
Кодування Base64 має свої корені в ранніх комп'ютерних та телекомунікаційних системах, де бінарні дані потрібно було передавати через канали, призначені для тексту.
Офіційна специфікація Base64 була вперше опублікована в 1987 році як частина RFC 989, яка визначала захищену електронну пошту (PEM). Це було пізніше оновлено в RFC 1421 (1993) та RFC 2045 (1996, як частина MIME).
Термін "Base64" походить від того, що кодування використовує 64 різні ASCII символи для представлення бінарних даних. Цей вибір 64 символів був свідомим, оскільки 64 є степенем двійки (2^6), що робить конверсію між бінарними даними та Base64 ефективною.
З часом з'явилося кілька варіантів Base64:
- Стандартний Base64: Як визначено в RFC 4648, використовуючи A-Z, a-z, 0-9, +, / та = для заповнення
- Безпечний для URL Base64: Використовує - та _ замість + та / для уникнення проблем з кодуванням URL
- Безпечний для імен файлів Base64: Схожий на безпечний для URL, призначений для використання в іменах файлів
- Модифікований Base64 для IMAP: Використовується в протоколі IMAP з іншим набором спеціальних символів
Незважаючи на те, що Base64 існує вже понад три десятиліття, він залишається основним інструментом в сучасних обчисленнях, особливо з ростом веб-додатків та API, які сильно покладаються на текстові формати даних, такі як JSON.
Приклади коду
Ось приклади кодування та декодування Base64 на різних мовах програмування:
1// JavaScript Base64 Кодування/Декодування
2function encodeToBase64(text) {
3 return btoa(text);
4}
5
6function decodeFromBase64(base64String) {
7 try {
8 return atob(base64String);
9 } catch (e) {
10 throw new Error("Недійсний рядок Base64");
11 }
12}
13
14// Приклад використання
15const originalText = "Hello, World!";
16const encoded = encodeToBase64(originalText);
17console.log("Закодовано:", encoded); // SGVsbG8sIFdvcmxkIQ==
18
19try {
20 const decoded = decodeFromBase64(encoded);
21 console.log("Декодовано:", decoded); // Hello, World!
22} catch (error) {
23 console.error(error.message);
24}
25
1# Python Base64 Кодування/Декодування
2import base64
3
4def encode_to_base64(text):
5 # Перетворити рядок у байти, а потім закодувати
6 text_bytes = text.encode('utf-8')
7 base64_bytes = base64.b64encode(text_bytes)
8 return base64_bytes.decode('utf-8')
9
10def decode_from_base64(base64_string):
11 try:
12 # Перетворити рядок base64 у байти, а потім декодувати
13 base64_bytes = base64_string.encode('utf-8')
14 text_bytes = base64.b64decode(base64_bytes)
15 return text_bytes.decode('utf-8')
16 except Exception as e:
17 raise ValueError(f"Недійсний рядок Base64: {e}")
18
19# Приклад використання
20original_text = "Hello, World!"
21encoded = encode_to_base64(original_text)
22print(f"Закодовано: {encoded}") # SGVsbG8sIFdvcmxkIQ==
23
24try:
25 decoded = decode_from_base64(encoded)
26 print(f"Декодовано: {decoded}") # Hello, World!
27except ValueError as e:
28 print(e)
29
1// Java Base64 Кодування/Декодування
2import java.util.Base64;
3import java.nio.charset.StandardCharsets;
4
5public class Base64Example {
6 public static String encodeToBase64(String text) {
7 byte[] textBytes = text.getBytes(StandardCharsets.UTF_8);
8 byte[] encodedBytes = Base64.getEncoder().encode(textBytes);
9 return new String(encodedBytes, StandardCharsets.UTF_8);
10 }
11
12 public static String decodeFromBase64(String base64String) {
13 try {
14 byte[] base64Bytes = base64String.getBytes(StandardCharsets.UTF_8);
15 byte[] decodedBytes = Base64.getDecoder().decode(base64Bytes);
16 return new String(decodedBytes, StandardCharsets.UTF_8);
17 } catch (IllegalArgumentException e) {
18 throw new IllegalArgumentException("Недійсний рядок Base64: " + e.getMessage());
19 }
20 }
21
22 public static void main(String[] args) {
23 String originalText = "Hello, World!";
24 String encoded = encodeToBase64(originalText);
25 System.out.println("Закодовано: " + encoded); // SGVsbG8sIFdvcmxkIQ==
26
27 try {
28 String decoded = decodeFromBase64(encoded);
29 System.out.println("Декодовано: " + decoded); // Hello, World!
30 } catch (IllegalArgumentException e) {
31 System.err.println(e.getMessage());
32 }
33 }
34}
35
1<?php
2// PHP Base64 Кодування/Декодування
3function encodeToBase64($text) {
4 return base64_encode($text);
5}
6
7function decodeFromBase64($base64String) {
8 $decoded = base64_decode($base64String, true);
9 if ($decoded === false) {
10 throw new Exception("Недійсний рядок Base64");
11 }
12 return $decoded;
13}
14
15// Приклад використання
16$originalText = "Hello, World!";
17$encoded = encodeToBase64($originalText);
18echo "Закодовано: " . $encoded . "\n"; // SGVsbG8sIFdvcmxkIQ==
19
20try {
21 $decoded = decodeFromBase64($encoded);
22 echo "Декодовано: " . $decoded . "\n"; // Hello, World!
23} catch (Exception $e) {
24 echo "Помилка: " . $e->getMessage() . "\n";
25}
26?>
27
1// C# Base64 Кодування/Декодування
2using System;
3using System.Text;
4
5class Base64Example
6{
7 public static string EncodeToBase64(string text)
8 {
9 byte[] textBytes = Encoding.UTF8.GetBytes(text);
10 return Convert.ToBase64String(textBytes);
11 }
12
13 public static string DecodeFromBase64(string base64String)
14 {
15 try
16 {
17 byte[] base64Bytes = Convert.FromBase64String(base64String);
18 return Encoding.UTF8.GetString(base64Bytes);
19 }
20 catch (FormatException)
21 {
22 throw new FormatException("Недійсний рядок Base64");
23 }
24 }
25
26 static void Main()
27 {
28 string originalText = "Hello, World!";
29 string encoded = EncodeToBase64(originalText);
30 Console.WriteLine($"Закодовано: {encoded}"); // SGVsbG8sIFdvcmxkIQ==
31
32 try
33 {
34 string decoded = DecodeFromBase64(encoded);
35 Console.WriteLine($"Декодовано: {decoded}"); // Hello, World!
36 }
37 catch (FormatException e)
38 {
39 Console.WriteLine($"Помилка: {e.Message}");
40 }
41 }
42}
43
1# Ruby Base64 Кодування/Декодування
2require 'base64'
3
4def encode_to_base64(text)
5 Base64.strict_encode64(text)
6end
7
8def decode_from_base64(base64_string)
9 begin
10 Base64.strict_decode64(base64_string)
11 rescue ArgumentError => e
12 raise "Недійсний рядок Base64: #{e.message}"
13 end
14end
15
16# Приклад використання
17original_text = "Hello, World!"
18encoded = encode_to_base64(original_text)
19puts "Закодовано: #{encoded}" # SGVsbG8sIFdvcmxkIQ==
20
21begin
22 decoded = decode_from_base64(encoded)
23 puts "Декодовано: #{decoded}" # Hello, World!
24rescue StandardError => e
25 puts "Помилка: #{e.message}"
26end
27
1// Go Base64 Кодування/Декодування
2package main
3
4import (
5 "encoding/base64"
6 "fmt"
7)
8
9func encodeToBase64(text string) string {
10 return base64.StdEncoding.EncodeToString([]byte(text))
11}
12
13func decodeFromBase64(base64String string) (string, error) {
14 bytes, err := base64.StdEncoding.DecodeString(base64String)
15 if err != nil {
16 return "", fmt.Errorf("недійсний рядок Base64: %v", err)
17 }
18 return string(bytes), nil
19}
20
21func main() {
22 originalText := "Hello, World!"
23 encoded := encodeToBase64(originalText)
24 fmt.Println("Закодовано:", encoded) // SGVsbG8sIFdvcmxkIQ==
25
26 decoded, err := decodeFromBase64(encoded)
27 if err != nil {
28 fmt.Println("Помилка:", err)
29 } else {
30 fmt.Println("Декодовано:", decoded) // Hello, World!
31 }
32}
33
1// Swift Base64 Кодування/Декодування
2import Foundation
3
4func encodeToBase64(_ text: String) -> String? {
5 if let data = text.data(using: .utf8) {
6 return data.base64EncodedString()
7 }
8 return nil
9}
10
11func decodeFromBase64(_ base64String: String) -> String? {
12 if let data = Data(base64Encoded: base64String) {
13 return String(data: data, encoding: .utf8)
14 }
15 return nil
16}
17
18// Приклад використання
19let originalText = "Hello, World!"
20if let encoded = encodeToBase64(originalText) {
21 print("Закодовано: \(encoded)") // SGVsbG8sIFdvcmxkIQ==
22
23 if let decoded = decodeFromBase64(encoded) {
24 print("Декодовано: \(decoded)") // Hello, World!
25 } else {
26 print("Помилка: Не вдалося декодувати рядок Base64")
27 }
28} else {
29 print("Помилка: Не вдалося закодувати текст")
30}
31
1' Excel VBA Base64 Кодування/Декодування
2' Примітка: Це вимагає посилання на Microsoft XML, v6.0
3Function EncodeToBase64(text As String) As String
4 Dim xmlObj As Object
5 Set xmlObj = CreateObject("MSXML2.DOMDocument")
6
7 Dim xmlNode As Object
8 Set xmlNode = xmlObj.createElement("b64")
9
10 xmlNode.DataType = "bin.base64"
11 xmlNode.nodeTypedValue = StrConv(text, vbFromUnicode)
12
13 EncodeToBase64 = xmlNode.text
14
15 Set xmlNode = Nothing
16 Set xmlObj = Nothing
17End Function
18
19Function DecodeFromBase64(base64String As String) As String
20 On Error GoTo ErrorHandler
21
22 Dim xmlObj As Object
23 Set xmlObj = CreateObject("MSXML2.DOMDocument")
24
25 Dim xmlNode As Object
26 Set xmlNode = xmlObj.createElement("b64")
27
28 xmlNode.DataType = "bin.base64"
29 xmlNode.text = base64String
30
31 DecodeFromBase64 = StrConv(xmlNode.nodeTypedValue, vbUnicode)
32
33 Set xmlNode = Nothing
34 Set xmlObj = Nothing
35 Exit Function
36
37ErrorHandler:
38 DecodeFromBase64 = "Помилка: Недійсний рядок Base64"
39End Function
40
41' Використання в аркуші:
42' =EncodeToBase64("Hello, World!")
43' =DecodeFromBase64("SGVsbG8sIFdvcmxkIQ==")
44
1# R Base64 Кодування/Декодування
2# Вимагає пакет 'base64enc'
3# install.packages("base64enc")
4library(base64enc)
5
6encode_to_base64 <- function(text) {
7 # Перетворити текст у сирі байти, а потім закодувати
8 text_raw <- charToRaw(text)
9 base64_encoded <- base64encode(text_raw)
10 return(rawToChar(base64_encoded))
11}
12
13decode_from_base64 <- function(base64_string) {
14 tryCatch({
15 # Перетворити рядок base64 у сирі байти, а потім декодувати
16 base64_raw <- charToRaw(base64_string)
17 decoded_raw <- base64decode(base64_raw)
18 return(rawToChar(decoded_raw))
19 }, error = function(e) {
20 stop(paste("Недійсний рядок Base64:", e$message))
21 })
22}
23
24# Приклад використання
25original_text <- "Hello, World!"
26encoded <- encode_to_base64(original_text)
27cat("Закодовано:", encoded, "\n") # SGVsbG8sIFdvcmxkIQ==
28
29tryCatch({
30 decoded <- decode_from_base64(encoded)
31 cat("Декодовано:", decoded, "\n") # Hello, World!
32}, error = function(e) {
33 cat("Помилка:", e$message, "\n")
34})
35
1% MATLAB Base64 Кодування/Декодування
2function demo_base64()
3 originalText = 'Hello, World!';
4
5 % Кодування
6 encoded = encode_to_base64(originalText);
7 fprintf('Закодовано: %s\n', encoded); % SGVsbG8sIFdvcmxkIQ==
8
9 % Декодування
10 try
11 decoded = decode_from_base64(encoded);
12 fprintf('Декодовано: %s\n', decoded); % Hello, World!
13 catch e
14 fprintf('Помилка: %s\n', e.message);
15 end
16end
17
18function encoded = encode_to_base64(text)
19 % Перетворити текст у масив uint8 і закодувати
20 bytes = uint8(text);
21 encoded = base64encode(bytes);
22end
23
24function decoded = decode_from_base64(base64String)
25 try
26 % Декодувати рядок base64 у масив uint8
27 bytes = base64decode(base64String);
28 decoded = char(bytes);
29 catch
30 error('Недійсний рядок Base64');
31 end
32end
33
1// C Base64 Кодування/Декодування за допомогою OpenSSL
2#include <stdio.h>
3#include <string.h>
4#include <openssl/bio.h>
5#include <openssl/evp.h>
6#include <openssl/buffer.h>
7#include <stdint.h>
8
9char* encode_to_base64(const char* input) {
10 BIO *bio, *b64;
11 BUF_MEM *bufferPtr;
12
13 b64 = BIO_new(BIO_f_base64());
14 bio = BIO_new(BIO_s_mem());
15 bio = BIO_push(b64, bio);
16
17 BIO_set_flags(bio, BIO_FLAGS_BASE64_NO_NL);
18 BIO_write(bio, input, strlen(input));
19 BIO_flush(bio);
20 BIO_get_mem_ptr(bio, &bufferPtr);
21
22 char* result = (char*)malloc(bufferPtr->length + 1);
23 memcpy(result, bufferPtr->data, bufferPtr->length);
24 result[bufferPtr->length] = '\0';
25
26 BIO_free_all(bio);
27
28 return result;
29}
30
31char* decode_from_base64(const char* input) {
32 BIO *bio, *b64;
33 size_t length = strlen(input);
34 char* buffer = (char*)malloc(length);
35
36 b64 = BIO_new(BIO_f_base64());
37 bio = BIO_new_mem_buf(input, -1);
38 bio = BIO_push(b64, bio);
39
40 BIO_set_flags(bio, BIO_FLAGS_BASE64_NO_NL);
41 int decoded_length = BIO_read(bio, buffer, length);
42
43 if (decoded_length <= 0) {
44 free(buffer);
45 BIO_free_all(bio);
46 return NULL; // Недійсний вхід Base64
47 }
48
49 buffer[decoded_length] = '\0';
50
51 BIO_free_all(bio);
52
53 return buffer;
54}
55
56int main() {
57 const char* original_text = "Hello, World!";
58
59 char* encoded = encode_to_base64(original_text);
60 printf("Закодовано: %s\n", encoded); // SGVsbG8sIFdvcmxkIQ==
61
62 char* decoded = decode_from_base64(encoded);
63 if (decoded) {
64 printf("Декодовано: %s\n", decoded); // Hello, World!
65 free(decoded);
66 } else {
67 printf("Помилка: Недійсний рядок Base64\n");
68 }
69
70 free(encoded);
71
72 return 0;
73}
74
1// Rust Base64 Кодування/Декодування
2use base64::{encode, decode};
3use std::str;
4
5fn encode_to_base64(text: &str) -> String {
6 encode(text)
7}
8
9fn decode_from_base64(base64_string: &str) -> Result<String, String> {
10 match decode(base64_string) {
11 Ok(bytes) => {
12 match str::from_utf8(&bytes) {
13 Ok(text) => Ok(text.to_string()),
14 Err(e) => Err(format!("Недійсна UTF-8 послідовність: {}", e))
15 }
16 },
17 Err(e) => Err(format!("Недійсний рядок Base64: {}", e))
18 }
19}
20
21fn main() {
22 let original_text = "Hello, World!";
23 let encoded = encode_to_base64(original_text);
24 println!("Закодовано: {}", encoded); // SGVsbG8sIFdvcmxkIQ==
25
26 match decode_from_base64(&encoded) {
27 Ok(decoded) => println!("Декодовано: {}", decoded), // Hello, World!
28 Err(e) => println!("Помилка: {}", e)
29 }
30}
31
Крайні випадки та зауваження
Коли ви працюєте з кодуванням та декодуванням Base64, зверніть увагу на ці важливі міркування:
-
Юнікод та не-ASCII символи: При кодуванні тексту з не-ASCII символами, забезпечте правильне кодування символів (зазвичай UTF-8) перед кодуванням Base64.
-
Заповнення: Стандартний Base64 використовує заповнення символами "=" для забезпечення того, щоб довжина виходу була кратною 4. Деякі реалізації дозволяють пропускати заповнення, що може викликати проблеми сумісності.
-
Переноси рядків: Традиційні реалізації Base64 вставляють перенос рядка (зазвичай кожні 76 символів) для читабельності, але сучасні додатки часто пропускають їх.
-
Безпечний для URL Base64: Стандартний Base64 використовує символи "+" та "/", які мають спеціальне значення в URL. Для контекстів URL використовуйте безпечний для URL Base64, який замінює ці символи на "-" та "_".
-
Пробіли: При декодуванні деякі реалізації є поблажливими і ігнорують пробіли, тоді як інші вимагають точного введення.
-
Збільшення розміру: Кодування Base64 збільшує розмір даних приблизно на 33% (4 вихідні байти на кожні 3 вхідні байти).
-
Продуктивність: Кодування/декодування Base64 може бути обчислювально інтенсивним для дуже великих даних. Розгляньте підходи до потокового оброблення для великих файлів.
Посилання
Зворотній зв'язок
Клацніть на спливаюче вікно зворотного зв'язку, щоб почати надавати відгуки про цей інструмент
Пов'язані Інструменти
Відкрийте більше інструментів, які можуть бути корисними для вашого робочого процесу