Base64エンコーダーとデコーダー:テキストをBase64に変換
テキストをBase64にエンコードするか、Base64文字列をテキストにデコードするための無料オンラインツール。標準およびURLセーフなBase64エンコーディングをサポートし、即時変換を提供します。
Base64 エンコーダ/デコーダ
テキストを Base64 エンコーディングに変換します
ドキュメント
Base64 エンコーダーとデコーダー
はじめに
Base64 は、バイナリデータを ASCII 文字列形式で表現するバイナリからテキストへのエンコーディング方式です。これは、バイナリ形式で保存されたデータを、テキストコンテンツのみを信頼性高くサポートするチャネルを介して運ぶために設計されています。Base64 エンコーディングは、バイナリデータを安全にテキストベースのプロトコルで送信できる 64 文字のセットに変換します(このため、名前が付けられています)。
Base64 文字セットは次のように構成されています:
- 大文字の A-Z(26 文字)
- 小文字の a-z(26 文字)
- 数字の 0-9(10 文字)
- 通常は「+」と「/」の 2 文字(2 文字)
このツールを使用すると、テキストを Base64 形式に簡単にエンコードしたり、Base64 文字列を元のテキストにデコードしたりできます。これは、開発者、IT プロフェッショナル、およびテキストベースのチャネルを介して安全に送信する必要があるデータに取り組んでいる人々に特に便利です。
Base64 エンコーディングの仕組み
エンコーディングプロセス
Base64 エンコーディングは、バイナリデータの 3 バイト(24 ビット)のグループを 4 つの Base64 文字に変換することによって機能します。このプロセスは次の手順に従います:
- 入力テキストをそのバイナリ表現に変換します(ASCII または UTF-8 エンコーディングを使用)
- バイナリデータを 24 ビット(3 バイト)のチャンクにグループ化します
- 各 24 ビットのチャンクを 4 つの 6 ビットグループに分割します
- 各 6 ビットグループを対応する Base64 文字に変換します
入力の長さが 3 で割り切れない場合、出力と入力の長さの 4:3 の比率を維持するために「=」文字でパディングが追加されます。
数学的表現
バイトのシーケンス に対して、対応する Base64 文字 は次のように計算されます:
ここで、 は Base64 アルファベットの 番目の文字を表します。
デコーディングプロセス
Base64 デコーディングはエンコーディングプロセスを逆転させます:
- 各 Base64 文字をその 6 ビット値に変換します
- これらの 6 ビット値を連結します
- ビットを 8 ビットのチャンク(バイト)にグループ化します
- 各バイトを対応する文字に変換します
パディング
エンコードするバイト数が 3 で割り切れない場合、パディングが適用されます:
- 1 バイトだけ残っている場合、それは 2 つの Base64 文字に変換され、「==」で終わります
- 2 バイト残っている場合、それらは 3 つの Base64 文字に変換され、「=」で終わります
例
テキスト「Hello」を Base64 にエンコードしてみましょう:
- 「Hello」の ASCII 表現: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
- 10 進数に変換:18, 6, 21, 44, 27, 6, 60
- Base64 アルファベットで調べる:S, G, V, s, b, G, 8
- 結果は「SGVsbG8=」です
入力の長さ(5 バイト)が 3 で割り切れないため、末尾に「=」のパディングがあります。
公式
Base64 エンコードされた文字列の長さを計算するための一般的な公式は次のとおりです:
ここで、 は天井関数(最も近い整数に切り上げる)を表します。
使用例
Base64 エンコーディングはさまざまなアプリケーションで広く使用されています:
-
メール添付ファイル:MIME(Multipurpose Internet Mail Extensions)は、メール内のバイナリ添付ファイルを Base64 でエンコードします。
-
データ URL:HTML、CSS、または JavaScript 内に小さな画像、フォント、または他のリソースを直接埋め込むために「data:」URL スキームを使用します。
-
API 通信:JSON ペイロードや他のテキストベースの API フォーマットでバイナリデータを安全に送信します。
-
テキストフォーマットでのバイナリデータの保存:バイナリデータを XML、JSON、または他のテキストベースのフォーマットに保存する必要がある場合。
-
認証システム:HTTP の基本認証は Base64 エンコーディングを使用します(ただし、セキュリティのためではなく、単にエンコーディングのためです)。
-
暗号化:さまざまな暗号プロトコルやシステムの一部として、しばしばキーや証明書をエンコードするために使用されます。
-
クッキーの値:クッキーに保存するために複雑なデータ構造をエンコードします。
代替案
Base64 は広く使用されていますが、特定の状況でより適切な代替案もあります:
-
URL セーフ Base64:URL エンコーディングの問題を避けるために「-」と「_」を使用するバリアント。URL に含まれるデータに便利です。
-
Base32:32 文字セットを使用し、出力が長くなりますが、人間の可読性が高く、大文字と小文字を区別しません。
-
16 進エンコーディング:単純に 16 進数に変換しますが、サイズが 2 倍になるため、非常に単純で広くサポートされています。
-
バイナリ転送:大きなファイルや効率が重要な場合、適切な Content-Type ヘッダーを使用した HTTP などの直接バイナリ転送プロトコルが好まれます。
-
圧縮 + Base64:大きなテキストデータの場合、エンコーディング前に圧縮することでサイズの増加を軽減できます。
-
JSON/XML シリアル化:構造化データの場合、Base64 エンコーディングよりもネイティブな JSON または XML シリアル化を使用する方が適切かもしれません。
歴史
Base64 エンコーディングは、バイナリデータをテキスト用に設計されたチャネルを介して送信する必要がある初期のコンピュータと電気通信システムにそのルーツを持っています。
Base64 の正式な仕様は、1987 年に RFC 989 の一部として初めて公開され、プライバシー強化メール(PEM)を定義しました。これは、RFC 1421(1993 年)および RFC 2045(1996 年、MIME の一部)で更新されました。
「Base64」という用語は、エンコーディングがバイナリデータを表現するために 64 の異なる ASCII 文字を使用することに由来します。この 64 文字の選択は意図的であり、64 は 2 の累乗(2^6)であるため、バイナリと Base64 の間の変換が効率的になります。
時が経つにつれ、Base64 のいくつかのバリアントが登場しました:
- 標準 Base64:RFC 4648 で定義され、A-Z、a-z、0-9、+、/ および = でパディングを使用
- URL セーフ Base64:URL エンコーディングの問題を避けるために - と _ を使用
- ファイル名セーフ Base64:ファイル名での使用を目的とした、URL セーフに似たもの
- IMAP 用の修正 Base64:IMAP プロトコルで使用される特別な文字の異なるセット
Base64 は、現代のコンピューティングにおいても基本的なツールであり続けており、特に JSON のようなテキストベースのデータフォーマットに依存するウェブアプリケーションや API の台頭に伴い重要性が増しています。
コード例
さまざまなプログラミング言語での 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 エンコーディングとデコーディングに取り組む際は、次の重要な考慮事項に注意してください:
-
Unicode および非 ASCII 文字:非 ASCII 文字を含むテキストをエンコードする場合、Base64 エンコーディングの前に適切な文字エンコーディング(通常は UTF-8)を確保してください。
-
パディング:標準の Base64 は、出力の長さが 4 の倍数になるように「=」文字でパディングを使用します。一部の実装ではパディングを省略することが許可されており、互換性の問題を引き起こす可能性があります。
-
改行:従来の Base64 実装は、可読性のために改行を挿入しますが、現代のアプリケーションではこれを省略することがよくあります。
-
URL セーフ Base64:標準の Base64 は「+」および「/」文字を使用しており、これらは URL で特別な意味を持ちます。URL コンテキストでは、URL セーフ Base64 を使用してこれらを「-」および「_」に置き換えます。
-
空白:デコーディング時、一部の実装は寛容で空白を無視しますが、他の実装は正確な入力を要求します。
-
サイズの増加:Base64 エンコーディングはデータのサイズを約 33% 増加させます(3 バイトの入力に対して 4 バイトの出力)。
-
パフォーマンス:非常に大きなデータに対して Base64 エンコーディング/デコーディングは計算集約的になる可能性があります。大きなファイルの場合はストリーミングアプローチを検討してください。
参考文献
フィードバック
フィードバックトーストをクリックして、このツールについてのフィードバックを始めてください
関連ツール
ワークフローに役立つかもしれない他のツールを発見してください