亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Base64 編碼介紹、Base64編碼轉(zhuǎn)換原理與算法

 更新時(shí)間:2016年06月04日 23:48:51   投稿:mdxy-dxy  
Base64編碼,是我們程序開(kāi)發(fā)中經(jīng)常使用到的編碼方法。它是一種基于用64個(gè)可打印字符來(lái)表示二進(jìn)制數(shù)據(jù)的表示方法,需要的朋友可以參考下

Base64編碼,是我們程序開(kāi)發(fā)中經(jīng)常使用到的編碼方法。它是一種基于用64個(gè)可打印字符來(lái)表示二進(jìn)制數(shù)據(jù)的表示方法。它通常用作存儲(chǔ)、傳輸一些二進(jìn)制數(shù)據(jù)編碼方法!也是MIME(多用途互聯(lián)網(wǎng)郵件擴(kuò)展,主要用作電子郵件標(biāo)準(zhǔn))中一種可打印字符表示二進(jìn)制數(shù)據(jù)的常見(jiàn)編碼方法!它其實(shí)只是定義用可打印字符傳輸內(nèi)容一種方法,并不會(huì)產(chǎn)生新的字符集!有時(shí)候,我們學(xué)習(xí)轉(zhuǎn)換的思路后,我們其實(shí)也可以結(jié)合自己的實(shí)際需要,構(gòu)造一些自己接口定義編碼方式。好了,我們一起看看,它的轉(zhuǎn)換思路吧!

Base64實(shí)現(xiàn)轉(zhuǎn)換原理

它是用64個(gè)可打印字符表示二進(jìn)制所有數(shù)據(jù)方法。由于2的6次方等于64,所以可以用每6個(gè)位元為一個(gè)單元,對(duì)應(yīng)某個(gè)可打印字符。我們知道三個(gè)字節(jié)有24個(gè)位元,就可以剛好對(duì)應(yīng)于4個(gè)Base64單元,即3個(gè)字節(jié)需要用4個(gè)Base64的可打印字符來(lái)表示。在Base64中的可打印字符包括字母A-Z、a-z、數(shù)字0-9 ,這樣共有62個(gè)字符,此外兩個(gè)可打印符號(hào)在不同的系統(tǒng)中一般有所不同。但是,我們經(jīng)常所說(shuō)的Base64另外2個(gè)字符是:“+/”。這64個(gè)字符,所對(duì)應(yīng)表如下。

編號(hào) 字符 編號(hào) 字符 編號(hào) 字符 編號(hào) 字符
0 A 16 Q 32 g 48 w
1 B 17 R 33 h 49 x
2 C 18 S 34 i 50 y
3 D 19 T 35 j 51 z
4 E 20 U 36 k 52 0
5 F 21 V 37 l 53 1
6 G 22 W 38 m 54 2
7 H 23 X 39 n 55 3
8 I 24 Y 40 o 56 4
9 J 25 Z 41 p 57 5
10 K 26 a 42 q 58 6
11 L 27 b 43 r 59 7
12 M 28 c 44 s 60 8
13 N 29 d 45 t 61 9
14 O 30 e 46 u 62 +
15 P 31 f 47 v 63 /

Base64編碼轉(zhuǎn)換算法、轉(zhuǎn)換原理

轉(zhuǎn)換的時(shí)候,將三個(gè)byte的數(shù)據(jù),先后放入一個(gè)24bit的緩沖區(qū)中,先來(lái)的byte占高位。數(shù)據(jù)不足3byte的話(huà),于緩沖區(qū)中剩下的bit用0補(bǔ)足。然后,每次取出6個(gè)bit,按照其值選擇
ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/中的字符作為編碼后的輸出。不斷進(jìn)行,直到全部輸入數(shù)據(jù)轉(zhuǎn)換完成。

如果最后剩下兩個(gè)輸入數(shù)據(jù),在編碼結(jié)果后加1個(gè)“=”;如果最后剩下一個(gè)輸入數(shù)據(jù),編碼結(jié)果后加2個(gè)“=”;如果沒(méi)有剩下任何數(shù)據(jù),就什么都不要加,這樣才可以保證資料還原的正確性。

編碼后的數(shù)據(jù)比原始數(shù)據(jù)略長(zhǎng),為原來(lái)的4/3。無(wú)論什么樣的字符都會(huì)全部被編碼,因此不像Quoted-printable 編碼,還保留部分可打印字符。所以,它的可讀性不如Quoted-printable 編碼!

文本 M a n
ASCII編碼 77 97 110
二進(jìn)制位 0 1 0 0 1 1 0 1 0 1 1 0 0 0 0 1 0 1 1 0 1 1 1 0
索引 19 22 5 46
Base64編碼 T W F u

M的Ascii碼是77,前六位對(duì)應(yīng)值為19,對(duì)應(yīng)base64字符是T,如此類(lèi)推。其它字符編碼就可以自動(dòng)轉(zhuǎn)換得到!我們看看另外不是剛好是3個(gè)字節(jié)的情況!

文本(1 Byte) A
二進(jìn)制位 0 1 0 0 0 0 0 1
二進(jìn)制位(補(bǔ)0) 0 1 0 0 0 0 0 1 0 0 0 0
Base64編碼 Q Q = =
文本(2 Byte) B C
二進(jìn)制位 0 1 0 0 0 0 1 0 0 1 0 0 0 0 1 1 x x x x x x
二進(jìn)制位(補(bǔ)0) 0 1 0 0 0 0 1 0 0 1 0 0 0 0 1 1 0 0 x x x x x x
Base64編碼 Q k M =

Base64轉(zhuǎn)換代碼實(shí)現(xiàn)

既然知道了方法,那么我們?nèi)绻约簩?xiě)個(gè)簡(jiǎn)單轉(zhuǎn)換,好像也是很容易的!下面,我寫(xiě)下我做轉(zhuǎn)換php代碼!

/**
 *base64編碼方法、本方法只是做base64轉(zhuǎn)換過(guò)程代碼舉例說(shuō)明,通過(guò)該例子可以任意改造不同語(yǔ)言版
 *@author 程默
 *@copyright http://blog.chacuo.net
 *@param $src 原字符串
 *@return string base64字符串*
 */
function c_base64_encode($src)
{
	static $base="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
	
	////將原始的3個(gè)字節(jié)轉(zhuǎn)換為4個(gè)字節(jié)
	$slen=strlen($src);
	$smod = ($slen%3);
	$snum = floor($slen/3);
	
	
	$desc = array();
	
	for($i=0;$i<$snum;$i++)
	{
		////讀取3個(gè)字節(jié)
		$_arr = array_map('ord',str_split(substr($src,$i*3,3)));
		
		///計(jì)算每一個(gè)base64值
		$_dec0= $_arr[0]>>2;
		$_dec1= (($_arr[0]&3)<<4)|($_arr[1]>>4);
		$_dec2= (($_arr[1]&0xF)<<2)|($_arr[2]>>6);	
		$_dec3= $_arr[2]&63;

		$desc = array_merge($desc,array($base[$_dec0],$base[$_dec1],$base[$_dec2],$base[$_dec3]));
	}
	
	if($smod==0) return implode('',$desc);
	
	///計(jì)算非3倍數(shù)字節(jié)
	$_arr = array_map('ord',str_split(substr($src,$snum*3,3)));
	$_dec0= $_arr[0]>>2;
	///只有一個(gè)字節(jié)
	if(!isset($_arr[1]))
	{
		$_dec1= (($_arr[0]&3)<<4);
		$_dec2=$_dec3="=";
	}
	else 
	{
		///2個(gè)字節(jié)
		$_dec1= (($_arr[0]&3)<<4)|($_arr[1]>>4);
		$_dec2= $base[($_arr[1]&7)<<2];
		$_dec3="=";
	}
	$desc = array_merge($desc,array($base[$_dec0],$base[$_dec1],$_dec2,$_dec3));
	return implode('',$desc);
}

好了,通過(guò)這個(gè)例子,我想base64編碼轉(zhuǎn)換原理、算法有些了解了吧!它轉(zhuǎn)換過(guò)程很簡(jiǎn)單,只需要做個(gè)映射表,然后將原先做一些移位運(yùn)算就可以完成!我們通過(guò)該例子,是不是可以做個(gè)自己的base32這類(lèi)的編碼呢!歡迎朋友們交流!

相關(guān)文章

  • 前端使用svg圖片改色實(shí)現(xiàn)示例

    前端使用svg圖片改色實(shí)現(xiàn)示例

    這篇文章主要為大家介紹了前端使用svg實(shí)現(xiàn)圖片改色的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • thymeleaf實(shí)現(xiàn)th:each雙重多重嵌套功能

    thymeleaf實(shí)現(xiàn)th:each雙重多重嵌套功能

    今天給大家分享一個(gè)使用 thymeleaf 實(shí)現(xiàn)一個(gè)動(dòng)態(tài)加載一二級(jí)文章分類(lèi)的功能,本文通過(guò)代碼講解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2019-11-11
  • Kali?Linux?2022.1安裝和相關(guān)配置教程(圖文詳解)

    Kali?Linux?2022.1安裝和相關(guān)配置教程(圖文詳解)

    這篇文章主要介紹了KaliLinux?2022.1安裝和相關(guān)配置,包括安裝系統(tǒng)和設(shè)置中文的方法,永久調(diào)節(jié)分辨率的相關(guān)技巧,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • chatGPT?deBug解決管理員登入服務(wù)器返回401問(wèn)題

    chatGPT?deBug解決管理員登入服務(wù)器返回401問(wèn)題

    這篇文章主要介紹了chatGPT?deBug解決管理員登入,服務(wù)器返回401,沒(méi)有拿到數(shù)據(jù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • gliffy UML工具安裝使用過(guò)程

    gliffy UML工具安裝使用過(guò)程

    這篇文章主要介紹了gliffy UML工具安裝使用過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • Burp Suite Pro安裝和配置使用教程詳解

    Burp Suite Pro安裝和配置使用教程詳解

    本文給大家分享的是Burp Suite Pro1.7.36安裝配置使用教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-09-09
  • RabbitMQ隊(duì)列中間件消息持久化?確認(rèn)機(jī)制?死信隊(duì)列原理

    RabbitMQ隊(duì)列中間件消息持久化?確認(rèn)機(jī)制?死信隊(duì)列原理

    這篇文章主要介紹了消息隊(duì)列中間件之RabbitMQ消息的持久化、確認(rèn)機(jī)制、死信隊(duì)列原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-05-05
  • Xmind8?Pro?最新激活序列號(hào)

    Xmind8?Pro?最新激活序列號(hào)

    最近需要打開(kāi)文件后綴名為.xmind的文件,所以下載了Xmind8?。打開(kāi)以后想要導(dǎo)出,奈何普通版本只能導(dǎo)出.txt文本文檔,所以就總結(jié)出了這篇文章,對(duì)Xmind8?Pro破解方法感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • Unicode編碼大揭秘

    Unicode編碼大揭秘

    這篇文章主要介紹了Unicode編碼大揭秘,本文介紹了編碼的歷史,Unicode的出現(xiàn)原因等,需要的朋友可以參考下
    2014-07-07
  • 軟件測(cè)試面試如何測(cè)試網(wǎng)頁(yè)的登錄頁(yè)面

    軟件測(cè)試面試如何測(cè)試網(wǎng)頁(yè)的登錄頁(yè)面

    本文主要介紹軟件測(cè)試面試如何測(cè)試網(wǎng)頁(yè)的登錄頁(yè)面,這里整理了相關(guān)軟件測(cè)試的一些基本知識(shí),希望能幫助軟件測(cè)試的同學(xué)
    2016-08-08

最新評(píng)論