一個案例讓你徹底搞懂base64編碼過程


簡介:Base64就是一種基於64個可打印字符來表示二進制數據的編碼方法。為什么不直接用ASCII碼呢?因為我們輸入的字符可能有ASCII碼中不可見的字符,為了完全可見,就用了base64編碼。

比如Hello這個單詞,我們把它變成base64編碼怎么做呢?

首先引入ASCII對照表:

2.一個字節是8個比特,先找到對應的ASCII碼,再將其轉化為8位的二進制,轉化如下:

H 對應碼值為72,它對應的二進制是 01001000

e對應碼值為101,它對應的二進制是:01100101

l對應碼值為108,它對應的二進制是:01101100

l對應碼值為108,它對應的二進制是:01101100

o對應碼值為111,它對應的二進制是:01101111

base64的碼值是0-63,所以用6位的二進制就可以完全表示base64的碼值(如:000000對應十進制0,111111對應的十進制為63),將上面8位一組的二進制變成6位一組的二進制,由於上面是5*8=40個二進制,不能被6整除,所以要加一組0將其變成48個二進制數(如果還是不能整除,還要繼續補8個0,其實就是最小公倍數的倍數)。

原來:01001000 01100101 01101100 01101100 01101111 00000000

現在:010010 000110 010101 101100 011011 000110 111100 000000

3.然后將6位一組的二進制計算出十進制,再跟base64的編碼表做對比,再將最后補位的0變成=,即可得到base64字符

010010 對應二進制是:18, 18對應base64字符為:S

000110 對應二進制是:6, 6對應base64字符為:G

010101 對應二進制是:21, 21對應base64字符為:V

101100 對應二進制是:44, 44對應base64字符為:s

011011 對應二進制是:27, 27對應base64字符為:b

000110 對應二進制是:6, 6對應base64字符為:G

111100 對應二進制是:18, 18對應base64字符為:8

000000 補位的0變成=

所以Hello對應的base64編碼就是:SGVsbG8=

這里貼上BASE64對照表:


參考或轉載:

https://blog.csdn.net/jtshongke/article/details/83505132


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM