Base64编码算法
轉(zhuǎn)載:http://www.cnblogs.com/xqxacm/p/4886299.html
?
一、什么是編碼解碼
編碼:利用特定的算法,對原始內(nèi)容進(jìn)行處理,生成運(yùn)算后的內(nèi)容,形成另一種數(shù)據(jù)的表現(xiàn)形式,可以根據(jù)算法,再還原回來,這種操作稱之為編碼。
解碼:利用編碼使用的算法的逆運(yùn)算,對經(jīng)過編碼的數(shù)據(jù)進(jìn)行處理,還原出原始數(shù)據(jù),這種操作稱之為解碼。
?
二、什么是Base64編碼算法
可以將任意的字節(jié)數(shù)組數(shù)據(jù),通過算法,生成只有(大小寫英文、數(shù)字、+、/)(一共64個字符)內(nèi)容表示的字符串?dāng)?shù)據(jù)。
即將任意的內(nèi)容轉(zhuǎn)換為可見的字符串形式。
?
三、Base64算法的由來
以前發(fā)送郵件只支持可見字符的傳送。由此,需要有一個方法將不可見的字符轉(zhuǎn)換為可見的字符,便產(chǎn)生了Base64編碼算法
?
四、Base64算法的特點(diǎn)
1、將數(shù)據(jù)按照?3個字節(jié)一組的形式進(jìn)行處理,每三個字節(jié)在編碼之后被轉(zhuǎn)換為4個字節(jié)。
即:如果一個數(shù)據(jù)有6個字節(jié),可編碼后將包含6/3*4=8個字節(jié)
2、當(dāng)數(shù)據(jù)的長度無法滿足3的倍數(shù)的情況下,最后的數(shù)據(jù)需要進(jìn)行填充操作,即補(bǔ)“=” ,這里“=”是填充字符,不要理解為第65個字符
?
eg: 三個字節(jié) ,轉(zhuǎn)換成 4個字節(jié) 的過程:
?
可以看出,將原始數(shù)據(jù)的 每三個字節(jié)分為一組,按位進(jìn)行分割為 每6位一個字節(jié)的形式,進(jìn)行轉(zhuǎn)換,形成新的4個字節(jié)。這四個字節(jié)才通過Base64編碼表進(jìn)行映射,形成最后實(shí)際的Base64編碼結(jié)果。
如果原始數(shù)據(jù)最后無法湊成3個字節(jié),則補(bǔ)填充,以“=”作為替換,代表沒有數(shù)據(jù)
?
五、
Base64編碼索引表
?
六、Base64使用場景
1、服務(wù)器給客戶端在JSON中傳遞二進(jìn)制數(shù)據(jù)
2、客戶端給服務(wù)器傳遞參數(shù)時,通過Base64傳遞二進(jìn)制內(nèi)容
?
七、注意點(diǎn)
1、Base64是編碼算法,不是加密算法,只是用來編碼字節(jié)數(shù)組,形成字符串的,并提供了解碼功能
2、Base64.encodeToString(byte[] data,int flag);
第二個參數(shù)設(shè)置NO_WRAP 即代表生成的字符串是否換行
Base64.encode(String str,int flag)同上
轉(zhuǎn)載于:https://www.cnblogs.com/songjy2116/p/7750234.html
與50位技術(shù)專家面對面20年技術(shù)見證,附贈技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的Base64编码算法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: UVA - 12166 Equilibr
- 下一篇: vivado hls(1)