čtvrtek 7. prosince 2023

Jak funguje base64?

Všichni to používají ale zda vůbec vědí jak se tato textová reprezentace binárních dat v ASCII vlastně převádí?

Binární data převedeme na 24 bitové číslo a to rozdělíme na skupiny o 6 bitech. Níže uvedená tabulka nám pomůže při kódování.

Máme binární data 01 02 03, 24 bit číslo bude 0x010203, to binárně zapsané vypadá 00000001 00000010 00000011. Nyní si data rozdělíme na šesti bitové skupiny, 000000 010000 001000 000011 (desítkové soustavě 1 16 8 3). Podle tabulky získáme AQID.

Pro data nesoudělná čtyřmi to funguje takto:

01 02, bude číslo 0x0102, tedy 00000001 00000010 binárně. Rozdělíme na šesti bitové skupiny, 000000 010000 0010, zprava přidáme nuly a vyjde nám AQI. Aby bylo možné detekovat padding, tak se doplní za každé dva bity znak =.


Příklad 01 02 03 04.

000000 010000 001000 000011 000001 000000

AQIDBA==

Dekódování se provádí opačně, jen se podle počtu znaků = data od konce oříznou. AA== je tedy 000000 00 0000 což je 00.

HexBinaryDecimalBase64
000000000A
010000011B
020000102C
030000113D
040001004E
050001015F
060001106G
070001117H
080010008I
090010019J
0A00101010K
0B00101111L
0C00110012M
0D00110113N
0E00111014O
0F00111115P
1001000016Q
1101000117R
1201001018S
1301001119T
1401010020U
1501010121V
1601011022W
1701011123X
1801100024Y
1901100125Z
1A01101026a
1B01101127b
1C01110028c
1D01110129d
1E01111030e
1F01111131f
2010000032g
2110000133h
2210001034i
2310001135j
2410010036k
2510010137l
2610011038m
2710011139n
2810100040o
2910100141p
2A10101042q
2B10101143r
2C10110044s
2D10110145t
2E10111046u
2F10111147v
3011000048w
3111000149x
3211001050y
3311001151z
34110100520
35110101531
36110110542
37110111553
38111000564
39111001575
3A111010586
3B111011597
3C111100608
3D111101619
3E11111062+
3F11111163/

Za vygenerování tabulky děkuji AI.

Žádné komentáře:

Okomentovat