Codificador i Decodificador Base64: Converteix Text a/from Base64
Eina en línia gratuïta per codificar text a Base64 o decodificar cadenes Base64 de nou a text. Admet codificació Base64 estàndard i segura per a URL amb conversió instantània.
Codificador/Decodificador Base64
Converteix text a i des de la codificació Base64
Documentació
Codificador i Decodificador Base64
Introducció
Base64 és un esquema de codificació de text a binari que representa dades binàries en un format de cadena ASCII. Està dissenyat per transportar dades emmagatzemades en formats binaris a través de canals que només suporten de manera fiable contingut de text. La codificació Base64 converteix dades binàries en un conjunt de 64 caràcters (d'aquí el nom) que poden ser transmesos de manera segura a través de protocols basats en text sense corrupció de dades.
El conjunt de caràcters Base64 consisteix en:
- Lletres majúscules A-Z (26 caràcters)
- Lletres minúscules a-z (26 caràcters)
- Dits 0-9 (10 caràcters)
- Dos caràcters addicionals, típicament "+" i "/" (2 caràcters)
Aquest eina et permet codificar fàcilment text al format Base64 o decodificar cadenes Base64 de nou al seu text original. És particularment útil per a desenvolupadors, professionals d'IT i qualsevol persona que treballi amb dades que necessiten ser transmeses de manera segura a través de canals basats en text.
Com Funciona la Codificació Base64
Procés de Codificació
La codificació Base64 funciona convertint cada grup de tres bytes (24 bits) de dades binàries en quatre caràcters Base64. El procés segueix aquests passos:
- Converteix el text d'entrada a la seva representació binària (utilitzant codificació ASCII o UTF-8)
- Agrupa les dades binàries en trossos de 24 bits (3 bytes)
- Divideix cada tros de 24 bits en quatre grups de 6 bits
- Converteix cada grup de 6 bits al seu caràcter Base64 corresponent
Quan la longitud de l'entrada no és divisible per 3, s'afegeix un ompliment amb caràcters "=" per mantenir la proporció de 4:3 de longituds de sortida a entrada.
Representació Matemàtica
Per a una seqüència de bytes , els caràcters Base64 corresponents es calculen com:
On representa el -è caracter de l'alfabet Base64.
Procés de Decodificació
La decodificació Base64 inverteix el procés de codificació:
- Converteix cada caràcter Base64 al seu valor de 6 bits
- Concatena aquests valors de 6 bits
- Agrupa els bits en trossos de 8 bits (bytes)
- Converteix cada byte al seu caràcter corresponent
Ompliment
Quan el nombre de bytes a codificar no és divisible per 3, s'aplica un ompliment:
- Si queda un byte, es converteix en dos caràcters Base64 seguits de "=="
- Si queden dos bytes, es converteixen en tres caràcters Base64 seguits de "="
Exemple
Vegem com codificar el text "Hello" a Base64:
- Representació ASCII de "Hello": 72 101 108 108 111
- Representació binària: 01001000 01100101 01101100 01101100 01101111
- Agrupament en trossos de 6 bits: 010010 000110 010101 101100 011011 000110 1111
- L'últim tros només té 4 bits, així que omplim amb zeros: 010010 000110 010101 101100 011011 000110 111100
- Convertint a decimal: 18, 6, 21, 44, 27, 6, 60
- Buscant a l'alfabet Base64: S, G, V, s, b, G, 8
- El resultat és "SGVsbG8="
Nota l'ompliment "=" al final perquè la longitud de l'entrada (5 bytes) no és divisible per 3.
Fórmula
La fórmula general per calcular la longitud d'una cadena codificada en Base64 és:
On representa la funció sostre (arrodonint cap amunt al nombre enter més proper).
Casos d'Ús
La codificació Base64 s'utilitza àmpliament en diverses aplicacions:
-
Arxius Adjunts d'Email: MIME (Extensions de Correu Internet Multimèdia) utilitza Base64 per codificar arxius adjunts binaris en correus electrònics.
-
URLs de Dades: Incorporar imatges petites, fonts o altres recursos directament en HTML, CSS o JavaScript mitjançant l'esquema d'URL
data:
. -
Comunicacions API: Transmetre de manera segura dades binàries en càrregues útils JSON o altres formats d'API basats en text.
-
Emmagatzematge de Dades Binàries en Formats de Text: Quan les dades binàries necessiten ser emmagatzemades en XML, JSON o altres formats basats en text.
-
Sistemes d'Autenticació: L'Autenticació Bàsica en HTTP utilitza la codificació Base64 (encara que no és per seguretat, només per codificació).
-
Criptografia: Com a part de diversos protocols i sistemes criptogràfics, sovint per codificar claus o certificats.
-
Valors de Cookies: Codificant estructures de dades complexes per ser emmagatzemades en cookies.
Alternatives
Si bé Base64 és àmpliament utilitzat, hi ha alternatives que podrien ser més apropiades en certes situacions:
-
Base64 Segur per a URL: Una variant que utilitza "-" i "_" en lloc de "+" i "/" per evitar problemes de codificació d'URL. Útil per a dades que s'inclouran en URLs.
-
Base32: Utilitza un conjunt de 32 caràcters, resultant en una sortida més llarga però amb millor llegibilitat humana i insensibilitat a majúscules.
-
Codificació Hexadecimal: Conversió simple a hexadecimal, que és menys eficient (duplica la mida) però molt simple i àmpliament suportada.
-
Transferència Binària: Per a fitxers grans o quan l'eficiència és crucial, els protocols de transferència binària directa com HTTP amb els encapçalaments de tipus de contingut apropiats són preferibles.
-
Compressió + Base64: Per a grans dades de text, comprimir abans de codificar pot mitigar l'augment de mida.
-
Serialització JSON/XML: Per a dades estructurades, utilitzar la serialització nativa JSON o XML podria ser més apropiat que la codificació Base64.
Història
La codificació Base64 té les seves arrels en els primers sistemes informàtics i de telecomunicacions on les dades binàries necessitaven ser transmeses a través de canals dissenyats per al text.
La especificació formal de Base64 es va publicar per primera vegada el 1987 com a part de l'RFC 989, que definia el Correu Privat Millorat (PEM). Això es va actualitzar més tard en l'RFC 1421 (1993) i l'RFC 2045 (1996, com a part de MIME).
El terme "Base64" prové del fet que la codificació utilitza 64 caràcters ASCII diferents per representar dades binàries. Aquesta elecció de 64 caràcters va ser deliberada, ja que 64 és una potència de 2 (2^6), cosa que fa que la conversió entre binari i Base64 sigui eficient.
Amb el temps, han emergit diverses variants de Base64:
- Base64 Estàndard: Tal com es defineix a l'RFC 4648, utilitzant A-Z, a-z, 0-9, +, / i = per a l'ompliment
- Base64 Segur per a URL: Utilitza - i _ en lloc de + i / per evitar problemes de codificació d'URL
- Base64 Segur per a Noms de Fitxers: Similar al segur per a URL, dissenyat per a l'ús en noms de fitxers
- Base64 Modificat per IMAP: Utilitzat en el protocol IMAP amb un conjunt diferent de caràcters especials
Malgrat tenir més de tres dècades, Base64 continua sent una eina fonamental en la informàtica moderna, particularment amb l'augment d'aplicacions web i APIs que depenen fortament de formats de dades basats en text com JSON.
Exemple de Codi
Aquí hi ha exemples de codificació i decodificació Base64 en diversos llenguatges de programació:
1// JavaScript Codificació/Decodificació 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("Cadena Base64 no vàlida");
11 }
12}
13
14// Exemple d'ús
15const originalText = "Hello, World!";
16const encoded = encodeToBase64(originalText);
17console.log("Codificat:", encoded); // SGVsbG8sIFdvcmxkIQ==
18
19try {
20 const decoded = decodeFromBase64(encoded);
21 console.log("Decodificat:", decoded); // Hello, World!
22} catch (error) {
23 console.error(error.message);
24}
25
1# Python Codificació/Decodificació Base64
2import base64
3
4def encode_to_base64(text):
5 # Convertir cadena a bytes i després codificar
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 # Convertir cadena base64 a bytes i després decodificar
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"Cadena Base64 no vàlida: {e}")
18
19# Exemple d'ús
20original_text = "Hello, World!"
21encoded = encode_to_base64(original_text)
22print(f"Codificat: {encoded}") # SGVsbG8sIFdvcmxkIQ==
23
24try:
25 decoded = decode_from_base64(encoded)
26 print(f"Decodificat: {decoded}") # Hello, World!
27except ValueError as e:
28 print(e)
29
1// Java Codificació/Decodificació 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("Cadena Base64 no vàlida: " + 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("Codificat: " + encoded); // SGVsbG8sIFdvcmxkIQ==
26
27 try {
28 String decoded = decodeFromBase64(encoded);
29 System.out.println("Decodificat: " + decoded); // Hello, World!
30 } catch (IllegalArgumentException e) {
31 System.err.println(e.getMessage());
32 }
33 }
34}
35
1<?php
2// PHP Codificació/Decodificació 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("Cadena Base64 no vàlida");
11 }
12 return $decoded;
13}
14
15// Exemple d'ús
16$originalText = "Hello, World!";
17$encoded = encodeToBase64($originalText);
18echo "Codificat: " . $encoded . "\n"; // SGVsbG8sIFdvcmxkIQ==
19
20try {
21 $decoded = decodeFromBase64($encoded);
22 echo "Decodificat: " . $decoded . "\n"; // Hello, World!
23} catch (Exception $e) {
24 echo "Error: " . $e->getMessage() . "\n";
25}
26?>
27
1// C# Codificació/Decodificació 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("Cadena Base64 no vàlida");
23 }
24 }
25
26 static void Main()
27 {
28 string originalText = "Hello, World!";
29 string encoded = EncodeToBase64(originalText);
30 Console.WriteLine($"Codificat: {encoded}"); // SGVsbG8sIFdvcmxkIQ==
31
32 try
33 {
34 string decoded = DecodeFromBase64(encoded);
35 Console.WriteLine($"Decodificat: {decoded}"); // Hello, World!
36 }
37 catch (FormatException e)
38 {
39 Console.WriteLine($"Error: {e.Message}");
40 }
41 }
42}
43
1# Ruby Codificació/Decodificació 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 "Cadena Base64 no vàlida: #{e.message}"
13 end
14end
15
16# Exemple d'ús
17original_text = "Hello, World!"
18encoded = encode_to_base64(original_text)
19puts "Codificat: #{encoded}" # SGVsbG8sIFdvcmxkIQ==
20
21begin
22 decoded = decode_from_base64(encoded)
23 puts "Decodificat: #{decoded}" # Hello, World!
24rescue StandardError => e
25 puts "Error: #{e.message}"
26end
27
1// Go Codificació/Decodificació 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("cadena Base64 no vàlida: %v", err)
17 }
18 return string(bytes), nil
19}
20
21func main() {
22 originalText := "Hello, World!"
23 encoded := encodeToBase64(originalText)
24 fmt.Println("Codificat:", encoded) // SGVsbG8sIFdvcmxkIQ==
25
26 decoded, err := decodeFromBase64(encoded)
27 if err != nil {
28 fmt.Println("Error:", err)
29 } else {
30 fmt.Println("Decodificat:", decoded) // Hello, World!
31 }
32}
33
1// Swift Codificació/Decodificació 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// Exemple d'ús
19let originalText = "Hello, World!"
20if let encoded = encodeToBase64(originalText) {
21 print("Codificat: \(encoded)") // SGVsbG8sIFdvcmxkIQ==
22
23 if let decoded = decodeFromBase64(encoded) {
24 print("Decodificat: \(decoded)") // Hello, World!
25 } else {
26 print("Error: No es pot decodificar la cadena Base64")
27 }
28} else {
29 print("Error: No es pot codificar el text")
30}
31
1' Excel VBA Codificació/Decodificació Base64
2' Nota: Això requereix una referència a 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 = "Error: Cadena Base64 no vàlida"
39End Function
40
41' Ús en una fulla de càlcul:
42' =EncodeToBase64("Hello, World!")
43' =DecodeFromBase64("SGVsbG8sIFdvcmxkIQ==")
44
1# R Codificació/Decodificació Base64
2# Requereix el paquet 'base64enc'
3# install.packages("base64enc")
4library(base64enc)
5
6encode_to_base64 <- function(text) {
7 # Convertir text a bytes crues, després codificar
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 # Convertir cadena base64 a bytes crues, després decodificar
16 base64_raw <- charToRaw(base64_string)
17 decoded_raw <- base64decode(base64_raw)
18 return(rawToChar(decoded_raw))
19 }, error = function(e) {
20 stop(paste("Cadena Base64 no vàlida:", e$message))
21 })
22}
23
24# Exemple d'ús
25original_text <- "Hello, World!"
26encoded <- encode_to_base64(original_text)
27cat("Codificat:", encoded, "\n") # SGVsbG8sIFdvcmxkIQ==
28
29tryCatch({
30 decoded <- decode_from_base64(encoded)
31 cat("Decodificat:", decoded, "\n") # Hello, World!
32}, error = function(e) {
33 cat("Error:", e$message, "\n")
34})
35
1% MATLAB Codificació/Decodificació Base64
2function demo_base64()
3 originalText = 'Hello, World!';
4
5 % Codificar
6 encoded = encode_to_base64(originalText);
7 fprintf('Codificat: %s\n', encoded); % SGVsbG8sIFdvcmxkIQ==
8
9 % Decodificar
10 try
11 decoded = decode_from_base64(encoded);
12 fprintf('Decodificat: %s\n', decoded); % Hello, World!
13 catch e
14 fprintf('Error: %s\n', e.message);
15 end
16end
17
18function encoded = encode_to_base64(text)
19 % Convertir text a uint8 array i codificar
20 bytes = uint8(text);
21 encoded = base64encode(bytes);
22end
23
24function decoded = decode_from_base64(base64String)
25 try
26 % Decodificar cadena base64 a uint8 array
27 bytes = base64decode(base64String);
28 decoded = char(bytes);
29 catch
30 error('Cadena Base64 no vàlida');
31 end
32end
33
1// C Codificació/Decodificació Base64 utilitzant 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; // Entrada Base64 no vàlida
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("Codificat: %s\n", encoded); // SGVsbG8sIFdvcmxkIQ==
61
62 char* decoded = decode_from_base64(encoded);
63 if (decoded) {
64 printf("Decodificat: %s\n", decoded); // Hello, World!
65 free(decoded);
66 } else {
67 printf("Error: Cadena Base64 no vàlida\n");
68 }
69
70 free(encoded);
71
72 return 0;
73}
74
1// Rust Codificació/Decodificació 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!("Seqüència UTF-8 no vàlida: {}", e))
15 }
16 },
17 Err(e) => Err(format!("Cadena Base64 no vàlida: {}", e))
18 }
19}
20
21fn main() {
22 let original_text = "Hello, World!";
23 let encoded = encode_to_base64(original_text);
24 println!("Codificat: {}", encoded); // SGVsbG8sIFdvcmxkIQ==
25
26 match decode_from_base64(&encoded) {
27 Ok(decoded) => println!("Decodificat: {}", decoded), // Hello, World!
28 Err(e) => println!("Error: {}", e)
29 }
30}
31
Casos Extrems i Consideracions
En treballar amb codificació i decodificació Base64, tingues en compte aquestes consideracions importants:
-
Unicode i Caràcters No ASCII: Quan codifiques text amb caràcters no ASCII, assegura't d'utilitzar la codificació de caràcters adequada (normalment UTF-8) abans de la codificació Base64.
-
Ompliment: La Base64 estàndard utilitza ompliment amb caràcters "=" per assegurar que la longitud de sortida sigui un múltiple de 4. Algunes implementacions permeten ometre l'ompliment, cosa que pot causar problemes de compatibilitat.
-
Salt de Línia: Les implementacions tradicionals de Base64 inserten salts de línia (típicament cada 76 caràcters) per llegibilitat, però les aplicacions modernes sovint els ometen.
-
Base64 Segur per a URL: La Base64 estàndard utilitza "+" i "/" que tenen significats especials en URLs. Per a contextos d'URL, utilitza Base64 segur per a URLs que substitueix aquests per "-" i "_".
-
Espai en Blanc: En decodificar, algunes implementacions són indulgents i ignoren espais en blanc, mentre que altres requereixen una entrada exacta.
-
Augment de Mida: La codificació Base64 augmenta la mida de les dades aproximadament un 33% (4 bytes de sortida per cada 3 bytes d'entrada).
-
Rendiment: La codificació/decodificació Base64 pot ser intensiva en computació per a dades molt grans. Considera enfocaments de flux per a fitxers grans.
Referències
Comentaris
Fes clic a la notificació de comentaris per començar a donar comentaris sobre aquesta eina
Eines relacionades
Descobreix més eines que podrien ser útils per al teu flux de treball